MySQL高级知识(十一)——数据库事务

1. 事务的原则介绍

2. 事务并发会造成的问题

3. MySQL的事务隔离级别

 

事务的原则

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

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

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

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

事务并发造成的问题

1、脏读

事务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读到的数据前后不一致。

3、幻读

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

比如:

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

MySQL的事务隔离级别

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

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

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

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

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值