MySQL数据库事务

数据库事务

1、概念

​ 执行批量操作时,这些操作作为一个整体,要么全部成功,要么全部失败。如银行转账,己方扣钱、对方加钱,这两个操作是一个整体,要么全部成功,要么全部失败。

2、四大特性ACID
  1. 原子性(Atomicity)
    • 事务是一个不可再分割的工作单位,事务中的操作要么都发生,要么都不发生
  2. 一致性(Consistency)
    • 事务前后,数据关系一致、业务逻辑一致
  3. 隔离性(Isolation)
    • 一个事务所做的修改在最终提交以前,对其他事务是不可见的
  4. 持久性(Duration)
    • 一旦事务提交,则更改是永久的
3、隔离级别
3.1 并发事务带来的问题
  • 脏读:一个事务读取了另一个事务未提交的数据,而这个数据是有可能回滚的;
  • 不可重复读:在数据库访问中,一个事务范围内两个相同的查询却返回了不同数据。这是由于查询时系统中其他事务修改的提交而引起的(不可重复读对应的是修改,即UPDATE操作);
  • 幻读:是指当事务不是独立执行时发生的一种现象,例如第一个事务对一个表中的数据进行了修改,这种修改涉及到表中的全部数据行。同时,第二个事务也修改这个表中的数据,这种修改是向表中插入一行新数据。那么,以后就会发生操作第一个事务的用户发现表中还有没有修改的数据行,就好象发生了幻觉一样(幻读问题对应的是插入INSERT操作);
  • 丢失更新: 两个事务同时读取同一条记录,A先修改记录,B也修改记录(B是不知道A修改过),B提交数据后B的修改结果覆盖了A的修改结果。
3.2 四种级别

数据库的事务隔离级别(TRANSACTION ISOLATION LEVEL)是一个数据库上很基本的一个概念。事务隔离级别的前提是一个多用户、多进程、多线程的并发系统,在这个系统中为了保证数据的一致性和完整性,从而引入了事务隔离级别这个概念,对一个单用户、单线程的应用来说则不存在这个问题。

​ 为了避免上述几种事务之间的影响,可以通过设置不同的隔离级别来进行不同程度的避免。因为高的隔离等级意味着更多的锁,从而牺牲性能。所以这个选项开放给了用户根据具体的需求进行设置。不过默认的隔离级别Read Commited符合了多数的实际需求。

隔离级别 描述 脏读 丢失更新 不可重复读 幻读 并发模型 更新冲突检测
读未提交:Read Uncommited 一个事务可以读取另一个未提交事务的数据 悲观
读已提交:Read commited 一个事务要等另一个事务提交后才能读取数据 悲观
可重复读:Repeatable Read 在开始读取数据(事务开启)时,不再允许修改操作 悲观
序列化:Serializable 最高的事务隔离级别,在该级别下,事务串行化顺序执行 悲观

​ 大多数数据库默认的事务隔离级别是Read committed,比如Sql Server ,OracleMySQL的默认隔离级别是Repeatable read

3.3 编辑隔离级别

1、修改my.ini配置文件

打开服务管理器(运行打开服务的命令services.msc),右键查看MySQL服务的属性找到my.ini所在路径(默认位置:C:\ProgramData\MySQL\MySQL Server 5.7\my.ini)。

这里写图片描述

在my.ini中设置,在mysqld选项中如下设置 [mysqld] transaction-isolation = READ-COMMITTED

2、命令行

命令行操作

  • select @@global.tx_isolation;
  • select @@tx_isolation;
  • set tx_isolation=’READ-COMMITTED’;
  • set global tx_isolation=’REPEATABLE-READ’;
4、几个API
无异常时提交修改:conn.commit()
发生异常时回滚:conn.rollback()
捕获异常时回滚:try ... except...
5、参考资料

猜你喜欢

转载自blog.csdn.net/lm_is_dc/article/details/80299811