mysql callback 事务性_细谈Mysql事务

文章原创于公众号:程序猿周先森。本平台不定时更新,喜欢我的文章,欢迎关注我的微信公众号。

fb3711a9e7d63beb18134dcf1bbaab6f.png

上一篇着重谈到了MySQL锁的概念,里面谈到了事务的概念,其实大部分开发者对于事务肯定不陌生,事务的概念其实就是一组SQL语句组成一个执行单元,如果单元中的某个SQL语句执行出现异常,则需要将整个事务进行回滚到未修改的状态。只有单元中全部SQL语句都成功执行,才会提交数据代表事务执行成功。而Mysql其实前几篇我们都已经知道是支持多种存储引擎的,其实正是因为MyISAM引擎不支持事务被InnoDB取代的原因。所以本篇文章主要是针对InnoDB引擎详细了解下事务这个概念。

事务特性

原子性: 事务是一个原子操作单元,其对数据的修改,要么全都执行,要么全都不执行。

一致性:事务中包含的处理要满足数据库提前设置的约束,如主键约束或者NOT NULL 约束等。

隔离性:事务处理过程中的中间状态对外部是不可见的。

持久性:事务完成之后,它对于数据的修改是永久性的。

隔离性的四种隔离级别

InnoDB引擎支持的4种事务隔离级别分别是:读未提交、读已提交、可重复读、串行读。

读未提交:允许脏读,可以读取其他session中未提交的脏数据。

读已提交:不可读取其他session尚未提交的数据,只有其他session数据已提交才能读取到,为不重复读。

可重复读:该级别下可重复读,InnoDB引擎默认采用可重复读,不允许读取还未提交的脏数据,但是可能存在InnoDB独有的幻读。

串行读:该级别下隔离程度最高,事务只能一个接着一个串行执行,无法并发执行。每次串行读都需要获得表级共享锁,读写操作都会阻塞。

幻读

事务在插入一条已经经过检查不存在的记录,但是插入结果是数据已经存在,之前的检查操作如同幻影。Mysql默认采用可重复读级别,所以只可能出现幻读的情况。

设置事务隔离级别

可以在my.ini文件中[mysqld]下配置transaction-isolation属性,隔离性的四个值为:READ-UNCOMMITTED、READ-COMMITIED、REPEATABLE-READ、SERIALIZABLE,分别对应读未提交、读已提交、可重复读、串行读四种隔离级别。

事务分类

事务一般分为两种:隐式事务和显示事务。在Mysql中,事务默认是自动提交的,所以说每个DML语句实际上就是一次事务的过程。

隐式事务:没有开启和结束的标志,默认执行完SQL语句就自动提交,比如我们经常使用的INSERT、UPDATE、DELETE语句就属于隐式事务。

显示事务:需要显示的开启关闭,然后执行一系列操作,最后如果全部操作都成功执行,则提交事务释放连接,如果操作有异常,则回滚事务中的所有操作。

事务使用步骤

开启事务:关闭自动提交,然后开启事务。

事务操作:一系列DML语句执行。

事务结束:根据事务操作成功与否选择提交事务或者回滚事务操作。

接下来我们简单的使用事务实现用户A向用户B转账的操作:

创建用户表并插入两条用户数据:

25ee90f6899f28c2c08e1ba202969c04.png

配置数据库连接信息:

78ae54f98883dc5624fb86f8a199a11d.png

接下来从连接池中取出一个数据库连接并进行数据库连接:

347b575fd42ae3afbc2e7124786d637a.png

数据库连接成功,则使用connection对象开启事务:

0ab78035f2eba5d9ec7a20d4ef2eaaca.png

然后查询转账账号与待转账账号是否存在,并进行转账等一系列操作,这里由于魔鬼回调的原因我这里使用async库变成链式调用:

fadf27f1e5022c6448192620a801ae3c.png

最后根据事务操作的成功或失败进行事务提交或者事务回滚,并且释放数据库连接:

c73413b9b536c24f33faf8c051143e03.png

然后可以测试转账成功的情况可以发现转账操作成功了

74b165d2c3e9a1327e09503580eec5f7.png

再次测试转账失败的操作可以发现扣除A积分和增加B积分的操作全部被回滚了,所以A和B的积分余额都没有发生改变

97933dd5f6b87cd09f96cf2ed219db10.png

欢迎关注公众号:程序猿周先森。文章原创于微信公众号,本平台不定时更新。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值