一、事务是什么
事务是一条或多条数据库操作语句的组合,具备ACID四个特征:
原子性(Atomicity)
要不全部成功,要不全部撤销。
一致性( Consistency )
数据库正确地改变状态后,数据库的一致性约束没有被破坏。
隔离性( Isolation )
事务之间相互独立,互不干扰。
持续性( Durability )
事务的提交结果,将持久保存在数据库中。
二、事务并发会产生的问题
如果在没有事务隔离的情况下,可能出现:
脏读
脏读是指当一个事务读取了一条数据,并对数据进行了修改,但是还没有提交,这时另外一个事务也读取了这条数据,然后使用了这条数据。如:用户的账户金额是100,T1将其修改为200,但是未提交,与此同时T2读取到用户账户金额是200,然后T1发生异常回滚,T2读到的200就是脏数据。
不可重复读
不可重复读是指对于数据库某一条数据,一个事务内多次查询但是返回了不同的值,这是由于在查询间隔,被另一个事务修改并提交了。
幻读
在一个事务的两次查询中数据行数不一致。例如一个事务查询了几列数据,而另外一个事务在此时插入了新的几列数据,第一个事务在接下来的查询中会发现有几列数据是它之前没有的,就好像产生幻觉一样,这就是发生了幻读。
三、事务隔离级别
事务隔离级别解决了什么并发问题,还存在什么并发问题?
1、Read Uncommitted(读取未提交内容)
这是事务最低的隔离级别,它充许另外一个事务可以看到这个事务未提交的数据。对并发出现的任何问题都无法避免。
2、Read Committed(读取提交内容)
保证一个事务修改的数据提交后才能被另外一个事务读取,即另外一个事务不能读取该事务未提交的数据。可避免脏读的发生,但是会出现不可重复读、幻读。
3、Repeatable Read(可重读)
这是MySQL的默认事务隔离级别,它确保同一事务的多个实例在并发读取数据时,会看到同样的数据。可避免脏读、不可重复读的发生,但是会出现幻读。
4、Serializable(可串行化)
这是最高的隔离级别,它通过强制事务排序,使之不可能相互冲突。在这个级别,可能导致大量的超时现象和锁竞争。可避免脏读、不可重复读、幻读的发生。
下一篇介绍InnoDB引擎的锁机制。
以上就是MySQL事务、锁以及应用(一)的内容,更多相关内容请关注PHP中文网(www.php.cn)!