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

 更新时间:2022年10月29日 09:02:56   作者:木木止月  
事务(Transaction)是访问和更新数据库的程序执行单元;事务中可能包含一个或多个sql语句,这些语句要么都执行,要么都不执行,下面这篇文章主要给大家介绍了关于MySQL基础教程之事务异常情况的相关资料,需要的朋友可以参考下

测试异常情况

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

控制事务一

查看/设置事务提交方式

SELECT @@autocommit ;
SET @@autocommit = 0 ;

提交事务

COMMIT;

回滚事务

ROLLBACK;

注意:

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

控制事务二

开启事务

START TRANSACTION 或 BEGIN ;

提交事务

COMMIT;

回滚事务

ROLLBACK;

转账案例:

-- 开启事务
start transaction
-- 1. 查询张三余额
select * from account where name = '张三';
-- 2. 张三的余额减少1000
update account set money = money - 1000 where name = '张三';
-- 3. 李四的余额增加1000
update 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事务异常情况内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • MySQL Order By语法介绍

    MySQL Order By语法介绍

    今天在使用ORDER BY的过程中出现了一点问题,发现之前对ORDER BY理解是错误的
    2012-07-07
  • MySQL 触发器(TRIGGER)的具体使用

    MySQL 触发器(TRIGGER)的具体使用

    本文主要介绍了MySQL 触发器(TRIGGER)的具体使用,包含INSERT 触发器,UPDATE触发器和DELETE触发器这三种,具有一定的参考价值,感兴趣的可以了解一下
    2024-05-05
  • MySQL索引的一些常见面试题大全(2022年)

    MySQL索引的一些常见面试题大全(2022年)

    索引(Index)是帮助MySQL高效获取数据的数据结构,是对表中一列或多列值进行排序的结构,下面这篇文章主要给大家介绍了关于MySQL索引的一些常见面试题,文中介绍的非常详细,需要的朋友可以参考下
    2023-02-02
  • Mysql数据库慢查询常用优化方式

    Mysql数据库慢查询常用优化方式

    数据库SQL优化是老生常谈的问题,下面这篇文章主要给大家介绍了关于Mysql数据库慢查询常用优化方式,文中通过实例代码介绍的非常详细,需要的朋友可以参考下
    2023-05-05
  • SQL深入探究存储的过程

    SQL深入探究存储的过程

    存储过程是事先经经过编译并存储在数据库中的一段SQL语句的集合,调用存储过程可以简化应用开发人员的很多工作,减少数据在数据库和应用服务器之间的传输,对于高效数据处理的效率是有好处的
    2023-01-01
  • MySQL数据库数据删除操作详解

    MySQL数据库数据删除操作详解

    本文我们将要学习的是作为删除数据使用的 “DELETE” 语句,“DELETE” 语句是用来删除数据的,它不能用来删除数据表本身。删除数据表使用的是 “DROP” 语句,而 “DELETE” 的作用只是用来删除记录而已
    2022-08-08
  • MySQL 触发器定义与用法简单实例

    MySQL 触发器定义与用法简单实例

    这篇文章主要介绍了MySQL 触发器定义与用法,结合简单实例形式总结分析了mysql触发器的语法、原理、定义及使用方法,需要的朋友可以参考下
    2019-09-09
  • 通过两种方式增加从库——不停止mysql服务

    通过两种方式增加从库——不停止mysql服务

    现在生产环境MySQL数据库是一主一从,由于业务量访问不断增大,故再增加一台从库。前提是不能影响线上业务使用,也就是说不能重启MySQL服务,为了避免出现其他情况,选择在网站访问量低峰期时间段操作
    2015-11-11
  • MySQL中主键与rowid的使用陷阱总结

    MySQL中主键与rowid的使用陷阱总结

    这篇文章主要给大家总结介绍了关于MySQL中主键与rowid的使用陷阱,文中通过示例代码介绍的非常详细,对大家的学习或者使用MySQL具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧
    2019-10-10
  • mysql 一次向表中插入多条数据实例讲解

    mysql 一次向表中插入多条数据实例讲解

    这篇文章主要介绍了mysql 一次向表中插入多条数据实例讲解的相关资料,需要的朋友可以参考下
    2016-10-10

最新评论