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