java事务相关知识汇总一

事务:

默认事务自动提交

触发时机:

DML执行:数据库操作语句的执行,例如insert,update,delete

DDL执行:数据定义语句

SELECT查询后结果集关闭后

存储过程执行后(数据结果集返回后,事务关闭)

 

事务隔离4大级别:

读未提交

读已提交

可重复读

可串行化

 

不同隔离级别可能出现的问题

脏读:A事务读,B事务写未提交,A事务能读取B事务没有提交的数据。

不可重复读:A事务读一行记录,B事务修改这条记录,A事务两次读取记录结果不一样。

幻读:A事务第一次读所有行记录,B事务添加记录提交,A事务会读到新增这一行记录。

 

注意:测试4种不能隔离级别,可能发现的问题时,一定记得把Mysql自动提交关闭

隔离级别指令:

设置:

SET [SESSION|GLOBAL] TRANSACTION ISOLATION LEVEL [READ UNCOMMITTED|READ COMMITTED|REPEATABLE READ|SERIALIZABLE]

查询

SELECT @@TX_ISOLATION

自动提交指令:

关闭:

SET AUTOCOMMIT=1

开启:

SET AUTOCOMMIT=0

转载于:https://my.oschina.net/u/1017791/blog/2885515

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值