spring事务提交回滚原理mybatis版
sping事務(wù)非常簡單好用,不用手動提交回滾事務(wù),比如下面代碼將2個更新操作一同提交,一同回滾。
上述代碼基本沒有任何有關(guān)jdbc事務(wù)的操作,?但卻能將2個數(shù)據(jù)庫更新操作同時提交與回滾,這是個值得思考的問題。通過思考并查閱spring源碼與資料,得出以下結(jié)論:
1: 圖中2個更新操作中,mybatis兩次更新以及spring回滾與提交過程中獲取的是同一個jdbc connection,connection是保存在ThreadLocal中。
2: 提交與回滾操作是spring通過事務(wù)攔截器+代理方式統(tǒng)一進(jìn)行的。
源碼分析:
? ?首先查看mybatis獲取數(shù)據(jù)庫連接的邏輯,代碼在mybatis-spring中的org.mybatis.spring.transaction.SpringManagedTransaction類。
? ? ?切換到DataSourceUtils.getConnection 方法,逐步定位獲取連接池的邏輯,此方法位于spring-jdbc下。
? ? ?通過連接池對象從ThreadLocal中獲取當(dāng)前線程綁定的數(shù)據(jù)庫連接:
? ? ?獲取到數(shù)據(jù)庫連接后必要時將數(shù)據(jù)庫連接寫到ThreadLocal中方便下次獲取:
? ? ?下面通過spring源碼分析spring處理事務(wù)邏輯,核心類是org.springframework.jdbc.datasource.DataSourceTransactionManager。
? ? ?首先查看spring獲取事務(wù)方法,從下圖可以看到獲取事務(wù)對應(yīng)的數(shù)據(jù)庫連接和mybatis中獲取connection走的是同一個方法,也是從ThreadLocal中獲取,這樣就保證在同一線程下與mybatis執(zhí)行sql時是同一個數(shù)據(jù)庫連接。
? ?接著查看此類的doCommit提交事務(wù)方法
? ?通過查找該方法使用位置,定位到以下代碼:
? ? ?逐步尋找最終在事務(wù)攔截器類org.springframework.transaction.interceptor.TransactionInterceptor 找到方法的最終調(diào)用者。
總結(jié)
以上是生活随笔為你收集整理的spring事务提交回滚原理mybatis版的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: mysql批量更新,批量插入之repla
- 下一篇: mysql InnoDB 聚集索引,二级