1、原子性:在事务中的操作,必须同时完成或者同时回滚,不会只成功或者回滚一部分。

2、一致性:不能破坏数据库的一致性状态。

3、隔离性:不同的事务之前互相不能影响。

4、持久性:事务完成以后,即保存数据,不会再回滚。

事务A读取了事务B更新的数据,然后B回滚操作,那么A读取到的数据是脏数据。

B把小明的年龄更新成12岁,但是事务还未提交。此时A来读小明的年龄,读到了12岁,然后去做自己的处理。之后B把小明的年龄回滚到11岁。这个例子中A读到的12岁就是脏数据。

2、不可重复读

事务A多次读取同一数据,事务B在事务A多次读取的过程中,对数据作了更新并提交,导致事务A多次读取同一数据时,结果不一致。

B先把小明的余额更新为100元,A来读的时候读到的是100元,然后B又把余额更新为90元,此时A来读的时候读到的就是90元,也就是A读到的数据前后不一致。

事务A对表中的数据进行了修改,涉及到表中的全部行。同时,事务B也修改这个表中的数据,向表中插入一行新数据。那么,事务A发现表中还有自己没有修改的行,就好象发生了幻觉一样。

A先把所有人的余额清零,同时,B往表中插入了一条余额为100的数据。A提交以后,发现竟然还有100的,命名刚刚都更新成0了呀。

1、读未提交:能读到未提交的数据。

2、读已提交:读已提交的数据。

3、可重复读:mysql默认,查询的都是事务开始时的数据。

4、串行读:完全串行化读,每次都会锁表,读写互相阻塞。

推荐阅读

相关文章:

你可能喜欢:

是因为自己真的有方向。