首页 > 其他分享 >事务面试题

事务面试题

时间:2023-01-29 12:22:31浏览次数:41  
标签:面试题 隔离 事务 并发 脏读 级别 读取

1.说下事务的ACID

原子性(Atomicity):原子性是指事务是一个不可分割的工作单位,事务中的操作要么都发生,要么都不发生,

一致性(Consistency):事务前后数据的完整性必须保持一致.

隔离性(Isolation):事务的隔离性是多个用户并发访问数据库时,数据库为每一个用户开启的事务,不能被其他事务的操作数据所干扰,多个并发事务之间要相互隔离,

持久性(Durability):持久性是指一个事务一旦被提交,它对数据库中数据的改变就是永久性的,接下来即使数据库发生故障也不应该对其有任何影响,

2.事务有哪几种隔离级别呢?

读未提交(read uncommitted)

另一个事务修改了数据,但尚未提交,而本事务中的select会读到这些未被提交的数据脏读.

读已提交(read committed)RC

事务能够看到的数据都是其他事务已经提交的修改,也就是保证不会看到任何中间性状态,当然脏读也不会出现,

可重复读(repeatable read)RR

保证同一个事务中多次读取的数据是一致的,这是MySQL InnoDB引擎的默认隔离级别.

串行(serializable)

并发事务之间是串行化的,通常意味着读取需要获取共享读锁.

更新需要获取排他写锁,如果SQL使用WHERE语句,还会获取区间锁,是最高的隔离级别.

3.事务的并发?什么是脏读?事务隔离级别,每个级别会引发什么问题?MySQL默认是哪个级别?

事务的并发问题

- 脏读 :脏读是指在一个事务处理过程中读取了另一个事务未提交的数据.

- 不可重复读,事务A多次读取同一数据,事务B在事务A多次读取的过程中,对数据作了更新并提交,导致事务A多次读取同一数据时,结果因此本事务先后两次读到的数据结果会不一致.

- 幻读:可重复读的隔离级别解决了不可重复读的问题,保证了同一个事务里.查询的结果都是事务开始时的状态(一致性).

**MySQL默认的事务隔离级别为repeatable-read(可重复读)**

MySql支持四种事务隔离级别

事务隔离的级别要得到底层数据库引擎的支持,而不是应用程序或者框架支持.

隔离级别越高,越能保证数据的完整性和一致性,但是对并发性能的影响也就越大,

可以优先考虑把数据库系统的隔离级别设为Read Committed,它能够避免脏读取,而且有较好的并发性能,

尽管他会导致不可重复读,幻读这些并发问题,在可能出现这类问题的个别场合,可以由应用程序采用悲观锁或乐观锁来控制.

4.不考虑事务的隔离级别会有什么问题

并发事务可能造成:脏读,不可重复读和幻读等问题,

这些问题其实都是数据库读一致性问题,必须由数据库提供一定的事务隔离机制来解决.

标签:面试题,隔离,事务,并发,脏读,级别,读取
From: https://www.cnblogs.com/carney/p/17072353.html

相关文章

  • 通信协议面试题
    1.名词解释IP协议TOC协议UDPIP协议分组交换协议不可靠传输一个数据包自动分成若干小的数据包然后通过网络进行传输TCP协议传输控制协议可靠协议建立在IP协议之......
  • SQLSERVER 事务日志的 LSN 到底是什么?
    SQLSERVER事务日志的LSN到底是什么? 一:背景1.讲故事大家都知道数据库应用程序 它天生需要围绕着数据文件打转,诸如包含数据的 .mdf,事务日志的 .ldf,很多时候深......
  • MySQL事务Read Committed隔离级别的数据可见性
    预先创建一张表test,表中只有一个字段state。createtabletest(stateintnotnull)engine=InnoDBcharset=utf8mb4;在两个终端中分别开启两个事务:事务的隔离......
  • 关于面试题的一些记录
    笔试1、谈谈你对三层架构的理解?2、C#中的委托是什么?事件是不是一种委托?事件和委托的关系。3、说出一些常用的类、接口,请各举5个4、什么是sql注入?如何避免sql注入?5、C#......
  • 集合面试题
    1.ArrayList和LinkedList的区别?ArrayList查询速度快(不准确),尾部增删快,头部增删慢,随机访问速度快;LinkedList头尾增删速度快,中间不高,性能远比ArrayList差,不适合做......
  • io流面试题
    1.Io流系介绍四大家族(IuputStream,OutputStream,Reader,Writer)IuputStream与OutputStream是所有字节型输入流的祖宗类.Reader与Writer是所有字节型输入输出流的祖宗类......
  • 基础语法面试题
    1.String , StringBuilder,StringBuffer的区别?(1)String只读字符串,引用的字符内容是不能被改变的.(2)StringBuilder和StringBuffer表示的字符串对象可以直接......
  • 互联网大厂(字节、华为)Java EE面试题:Servlet/JSP 部分解析+答案,最强八股文
    文章目录​​1.请列举至少6种javaEE技术,并简述其作用。​​​​解析:​​​​参考答案:​​​​2.在web.xml文件中配置Servlet时,主要配置哪些信息?​​​​解析:​​​​参考答......
  • 算法面试题
    有一列数的规则如下: 1、1、2、3、5、8、13、21、34...... 求第30位数是多少,用递归算法实现。1intAdd(intnumber)2{3if(number<=0)4{5......
  • EAS查找/停止正在运行的后台事务SQL语句
    EAS查找正在运行的后台事务SQL语句select*fromT_job_instwhereFSTATE='Running'andFTITLELIKE'%商务卡%'EAS停止正在运行的后台事务SQL语句updateT_job_ins......