MySQL事务

Mysql事务

事务可以保证多个操作的原子性,要么全成功,要么全失败,对于数据库来说事务保证批量DML要么全成功,要么全失败,事务具体有四个特征ACID

  • 原子性
    整个事务中的所有操作,必须作为一个单元全部完成(或全部取消)

  • 一致性
    在事务开始之前与结束之后,数据库都保存一致状态

  • 隔离性
    一个事务不会影响其他事务的运行

  • 持久性
    在事务完成之后,该事务对数据库所作的更改将持久的保存在数据库之中,并不会被回滚

事务存在的一些概念

● 事务(Transaction):一批操作(一组DML)

● 开启事务(Start Transaction)

● 回滚事务(rollback)

● 提交事务(commit)
● SET AUTOCOMMIT:禁用或启用事务的自动提交模式

当执行DML语句是其实就是开启一个事务;

关于事务的回滚需要注意:只能回滚insert、delete和update语句,不能回滚select(回滚select没有任何意义),对于create、drop、alter这些无法回滚事务只对DML有效果。

注意:rollback,或者commit后事务就结束了。

Mysql的事务隔离级别

隔离级别

1、事务的隔离级别决定了事务之间可见的级别。

2、当多个客户端并发地访问同一个表时,可能出现下面的一致性问题:
● 脏读取(Dirty Read)

一个事务开始读取了某行数据,但是另外一个事务已经更新了此数据但没有能够及时提交,这就出现了脏读取。

● 不可重复读(Non-repeatable Read)

在同一个事务中,同一个读操作对同一个数据的前后两次读取产生了不同的结果,这就是不可重复读。

● 幻像读(Phantom Read)

幻像读是指在同一个事务中以前没有的行,由于其他事务的提交而出现的新行。
四个隔离级别

InnoDB 实现了四个隔离级别,用以控制事务所做的修改,并将修改通告至其它并发的事务:

● 读未提交(READ UMCOMMITTED)

允许一个事务可以看到其他事务未提交的修改

● 读已提交(READ COMMITTED)

允许一个事务只能看到其他事务已经提交的修改,未提交的修改是不可见的

● 可重复读(REPEATABLE READ)

确保如果在一个事务中执行两次相同的SELECT语句,都能得到相同的结果,不管其他事务是否提交这些修改。 (银行总账)

该隔离级别为InnoDB的缺省设置

● 串行化(SERIALIZABLE) 【序列化】

将一个事务与其他事务完全地隔离。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值