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