前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Mybatis事务隔离级别「建议收藏」

Mybatis事务隔离级别「建议收藏」

作者头像
全栈程序员站长
发布2022-11-04 10:58:09
7470
发布2022-11-04 10:58:09
举报
文章被收录于专栏:全栈程序员必看

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。 Jetbrains全系列IDE稳定放心使用

转载:https://blog.csdn.net/qq924862077/article/details/52599961

一般数据库的隔离级别有4个,由低到高依次为Read uncommitted、Read committed、Repeatable read、Serializable,这四个级别可以逐个解决脏读、不可重复读、幻读这几类问题。

√: 可能出现 ×: 不会出现

脏读

不可重复读

幻读

说明

Read uncommitted

直译就是”读未提交”,意思就是即使一个更新语句没有提交,但是别 的事务可以读到这个改变.这是很不安全的。允许任务读取数据库中未提交的数据更改,也称为脏读。

Read committed

×

直译就是”读提交”,可防止脏读,意思就是语句提交以后即执行了COMMIT以后 别的事务就能读到这个改变. 只能读取到已经提交的数据。Oracle等多数数据库默认都是该级别

Repeatable read

×

×

直译就是”可以重复读”,这是说在同一个事务里面先后执行同一个查询语句的时候,得到的结果是一样的.在同一个事务内的查询都是事务开始时刻一致的,InnoDB默认级别。在SQL标准中,该隔离级别消除了不可重复读,但是还存在幻象读

Serializable

×

×

×

直译就是”序列化”,意思是说这个事务执行的时候不允许别的事务并发执行. 完全串行化的读,每次读都需要获得表级共享锁,读写相互都会阻塞

Mybatis也是提供了如上表所示的隔离级别,只不过增加了一种没有事务,源码如下:

[java] view plain copy

  1. /**
  2. * @author Clinton Begin
  3. */
  4. public enum TransactionIsolationLevel {
  5. NONE(Connection.TRANSACTION_NONE),
  6. READ_COMMITTED(Connection.TRANSACTION_READ_COMMITTED),
  7. READ_UNCOMMITTED(Connection.TRANSACTION_READ_UNCOMMITTED),
  8. REPEATABLE_READ(Connection.TRANSACTION_REPEATABLE_READ),
  9. SERIALIZABLE(Connection.TRANSACTION_SERIALIZABLE);
  10. private final int level;
  11. private TransactionIsolationLevel(int level) {
  12. this.level = level;
  13. }
  14. public int getLevel() {
  15. return level;
  16. }
  17. }

这样在DefaultSqlSessionFactory中创建SqlSession时,可以设置数据库的事务隔离级别,以及通过设置autoCommit来设置事务的提交方式,方式如下:

当autoCommit=false时,插入的数据报错时,修改的内容不会提交到数据库,但是如果没有进行rollback回滚操作时就会造成数据库死锁问题

当autoCommit = true对连续的操作数据中间出现错误时会部分提交,导致产生脏数据。

[java] view plain copy

  1. private SqlSession openSessionFromDataSource(ExecutorType execType, TransactionIsolationLevel level, boolean autoCommit)

Mybatis提供的事务隔离级别完全契合数据库事务隔离级别方式。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/182198.html原文链接:https://javaforall.cn

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2022年10月14日,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
数据库
云数据库为企业提供了完善的关系型数据库、非关系型数据库、分析型数据库和数据库生态工具。您可以通过产品选择和组合搭建,轻松实现高可靠、高可用性、高性能等数据库需求。云数据库服务也可大幅减少您的运维工作量,更专注于业务发展,让企业一站式享受数据上云及分布式架构的技术红利!
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档