MySQL基础教程之事务异常情况

2022-11-28 0 720

目录测试异常情况控制事务一查看/设置事务提交方式提交事务回滚事务注意:控制事务二开启事务提交事务回滚事务转账案例:事务四大特性补充:Mysql 事务并发处理的三种异常总结

测试异常情况– 1. 查询张三余额select * from account where name = \’张三\’;– 2. 张三的余额减少1000update account set money = money – 1000 where name = \’张三\’;出错了….– 3. 李四的余额增加1000update account set money = money + 1000 where name = \’李四\’;我们把数据都恢复到2000, 然后再次一次性执行上述的SQL语句(出错了…. 这句话不符合SQL语 法,执行就会报错),检查最终的数据情况, 发现数据在操作前后不一致了。

MySQL基础教程之事务异常情况

控制事务一

查看/设置事务提交方式SELECT @@autocommit ;SET @@autocommit = 0 ;

提交事务

COMMIT;

回滚事务

ROLLBACK;

注意:

上述的这种方式,我们是修改了事务的自动提交行为, 把默认的自动提交修改为了手动提 交, 此时我们执行的DML语句都不会提交, 需要手动的执行commit进行提交。

控制事务二

开启事务START TRANSACTION 或 BEGIN ;提交事务

COMMIT;

回滚事务

ROLLBACK;

转账案例:– 开启事务start transaction– 1. 查询张三余额select * from account where name = \’张三\’;– 2. 张三的余额减少1000update account set money = money – 1000 where name = \’张三\’;– 3. 李四的余额增加1000update account set money = money + 1000 where name = \’李四\’;– 如果正常执行完毕, 则提交事务commit;– 如果执行过程中报错, 则回滚事务– rollback;

事务四大特性原子性(Atomicity):事务是不可分割的最小操作单元,要么全部成功,要么全部失败。一致性(Consistency):事务完成时,必须使所有的数据都保持一致状态。隔离性(Isolation):数据库系统提供的隔离机制,保证事务在不受外部并发操作影响的独立环境下运行。持久性(Durability):事务一旦提交或回滚,它对数据库中的数据的改变就是永久的。上述就是事务的四大特性,简称ACID。

补充:Mysql 事务并发处理的三种异常

脏读(Dirty Read)【一个事务可能读取到另一个事务更新但未提交的数据,这个数据有可能是脏数据】

不可重复读(Nnrepeatable Read)【事务不可重复读同一条记录,因为很可能读到的结果不一致】

幻读(Phantom Read)【幻读就是没有读到的记录,以为不存在,但其实是可以更新成功的,并且,更新成功后,再次读取,就出现了。】

A1访问数据库,正在进行事务,往表B里加入一条记录,但是还未提交该事务,此时A2也去访问数据库了,这个时候,A2可以看到A1加入的数据,这种现象就是脏读。

A2访问数据库查看id=1的数据,这个时候A1访问数据库,开始了一个事务,更新了id=1的数据,且没有提交。然后A2又去访问数据库查看id=1的数据,看到的数据跟第一次看到的数据不一样,而是A1更新的数据,这种现象就是不可重复读。

A2访问数据库,查看B表里的全部数据。这个时候A1又往B表里加一条记录,开始了事务但是还未提交。这个时候A2又去查看了一下,就出现了A1加进去的但还未提交的数据,这种现象就是幻读。

总结

到此这篇关于MySQL基础教程之事务异常情况的文章就介绍到这了,更多相关MySQL事务异常情况内容请搜索悠久资源网以前的文章或继续浏览下面的相关文章希望大家以后多多支持悠久资源网!

收藏 (0) 打赏

感谢您的支持,我会继续努力的!

打开微信/支付宝扫一扫,即可进行扫码打赏哦,分享从这里开始,精彩与您同在
点赞 (0)

悠久资源 Mysql数据库 MySQL基础教程之事务异常情况 https://www.u-9.cn/sql/mysql/688.html

常见问题

相关文章

发表评论
暂无评论
官方客服团队

为您解决烦忧 - 24小时在线 专业服务

  • 0 +

    访问总数

  • 0 +

    会员总数

  • 0 +

    文章总数

  • 0 +

    今日发布

  • 0 +

    本周发布

  • 0 +

    运行天数

注册会员,众多资源免费下载