日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

詳解MySQL與Spring的自動提交(autocommit)

瀏覽:111日期:2023-02-06 09:07:26
1 MySQL的autocommit設置

MySQL默認是開啟自動提交的,即每一條DML(增刪改)語句都會被作為一個單獨的事務進行隱式提交。如果修改為關閉狀態,則執行DML語句之后要手動提交 才能生效。查詢當前會話的自動提交是否開啟:

mysql> show variables like ’autocommit’;+---------------+-------+| Variable_name | Value |+---------------+-------+| autocommit | ON |+---------------+-------+

查詢全局的自動提交是否開啟:

mysql> show global variables like ’autocommit’;+---------------+-------+| Variable_name | Value |+---------------+-------+| autocommit | ON |+---------------+-------+

通過修改autocommit變量可以關閉和開啟操作

關閉當前會話的自動提交模式mysql> set autocommit=0; mysql> show variables like ’autocommit’;+---------------+-------+| Variable_name | Value |+---------------+-------+| autocommit | OFF |+---------------+-------+ 全局的autocommit還是開啟狀態mysql> show global variables like ’autocommit’;+---------------+-------+| Variable_name | Value |+---------------+-------+| autocommit | ON |+---------------+-------+ 關閉全局的autocommitmysql> set global autocommit=0; mysql> show global variables like ’autocommit’;+---------------+-------+| Variable_name | Value |+---------------+-------+| autocommit | OFF |+---------------+-------+

如果想要MySQL服務重啟之后仍能生效,需要設置系統環境變量。MySQL5.7 在cnf配置文件中[mysqld]下面設置autocommit的值。

[mysqld]...autocommit=0Spring中對自動提交的控制

MySQL的JDBC驅動包 mysql-connector-java 會給會話的connection默認開啟自動提交,譬如 mysql-connector-java-8.0.22版本的代碼:

//com.mysql.cj.protocol.a.NativeServerSession.java private boolean autoCommit = true;

常用的數據庫連接池 如HikariCP,druid等,默認也是開啟自動提交,會將connection的自動提交設置都改為true。druid在初始化DataSource的時候設置connection的autocommit為true。代碼如下:

com.alibaba.druid.pool.DruidAbstractDataSource.java protected volatile boolean defaultAutoCommit = true; ... public void initPhysicalConnection(Connection conn, Map<String, Object> variables, Map<String, Object> globalVariables) throws SQLException { if (conn.getAutoCommit() != defaultAutoCommit) { //將connection的autocommit設置為true conn.setAutoCommit(defaultAutoCommit); } ... }

HikariCP 初始化DataSource的默認配置 中autocommit也是true:

com.zaxxer.hikari.HikariConfig.java public HikariConfig() { ... isAutoCommit = true; }

對于事務管理器PlatformTransactionManager管理的顯式事務(譬如@Transactional注解聲明)在 開啟事務時會關閉自動提交模式。 代碼如下:

@Overrideprotected void doBegin(Object transaction, TransactionDefinition definition) {DataSourceTransactionObject txObject = (DataSourceTransactionObject) transaction;Connection con = null;try { ........// Switch to manual commit if necessary. This is very expensive in some JDBC drivers,// so we don’t want to do it unnecessarily (for example if we’ve explicitly// configured the connection pool to set it already).if (con.getAutoCommit()) {txObject.setMustRestoreAutoCommit(true);if (logger.isDebugEnabled()) {logger.debug('Switching JDBC Connection [' + con + '] to manual commit');}//關閉自動提交模con.setAutoCommit(false);} .......}catch (Throwable ex) { .......}}總結

MySQL的autocommit模式默認是打開狀態,為了防止手動的DML操作導致失誤,生產環境可以設置為默認關閉的狀態。一般的jdbc 連接池默認都是開啟狀態,而且是可配置的。顯式事務下會設置成關閉狀態,單純的修改數據庫環境的autocommit不會對代碼的行為產生影響。

以上就是詳解MySQL與Spring的自動提交(autocommit)的詳細內容,更多關于MySQL 自動提交(autocommit)的資料請關注好吧啦網其它相關文章!

標簽: Spring
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
日韩一区欧美二区| 日韩不卡一区| 日韩专区精品| 国产乱人伦精品一区| 久久成人一区| 欧美一区三区| 群体交乱之放荡娇妻一区二区| 国产伦精品一区二区三区视频| 一区二区不卡| 日韩精品a在线观看91| 国产精品毛片在线看| 国产高清一区| 久久三级福利| 成人av三级| 日韩毛片网站| 欧美一区在线观看视频| 四虎在线精品| 国产精品对白| 久久av导航| 国产精品**亚洲精品| 久久亚洲人体| 久久精品三级| 久久精品国产99国产| 国产精品v亚洲精品v日韩精品| 欧美一级二级三级视频| 国产精品一区二区三区美女| 欧美日韩午夜| 久久精选视频| 国产在线欧美| 99精品小视频| 一本综合精品| 天堂va在线高清一区| 日韩精品欧美大片| 美女国产精品久久久| 精品视频一二| 九九在线精品| 人人爽香蕉精品| 亚洲免费专区| 久久三级中文| 福利视频一区| 久久xxxx| 亚洲精品国产精品粉嫩| 亚洲a级精品| 欧美激情日韩| 成人av三级| 在线精品亚洲| 国产精品夜夜夜| 国产一区二区色噜噜| 欧美另类专区| 视频一区中文字幕精品| 成人午夜网址| 欧美日韩国产一区二区三区不卡| 高清av不卡| 午夜久久99| 日韩欧美高清一区二区三区| 97国产成人高清在线观看| 久久高清精品| 日韩在线观看中文字幕| 欧美韩一区二区| 欧美一区久久久| 一区二区三区网站| 国产精品毛片久久久| 麻豆极品一区二区三区| 中文字幕在线官网| 在线视频日韩| 国产精品一国产精品k频道56| 久久国产欧美| 久久先锋影音| 都市激情国产精品| 日韩一级网站| 日本a口亚洲| 亚洲成人日韩| 日韩成人午夜精品| 日韩精品久久久久久久电影99爱 | 久久午夜影院| 日韩午夜黄色| 国产精品极品在线观看| 免费日韩av片| 精品一区二区三区中文字幕在线| 欧美va天堂在线| 日韩高清一区二区| 伊人久久国产| 国产精品午夜一区二区三区| 99精品视频在线| 久久中文在线| 一本色道精品久久一区二区三区| 日日夜夜免费精品| 免费久久久久久久久| 国产图片一区| 免费成人在线观看| 国产一区二区三区不卡av| 午夜一区在线| 91精品一区二区三区综合| 欧美精品中文字幕亚洲专区| 免费人成网站在线观看欧美高清| 国产66精品| 日本不卡一区二区三区| 鲁大师影院一区二区三区| 久久久久黄色| 97精品资源在线观看| 久久久久91| 免费人成网站在线观看欧美高清| 欧美日韩第一| yellow在线观看网址| 美日韩一区二区三区| 亚洲欧美日韩国产综合精品二区| 97精品视频在线看| 久久激五月天综合精品| 亚洲黄页一区| 欧美va天堂| 正在播放日韩精品| 精品伊人久久| 日韩av网站在线免费观看| 亚洲午夜久久久久久尤物| а√在线中文在线新版| 日韩欧美在线精品| 亚洲一区二区免费在线观看| 亚洲精品.com| 精品久久97| 精品日韩一区| 日本一区中文字幕| 亚洲免费观看高清完整版在线观| 激情婷婷亚洲| 日本视频在线一区| 亚洲精选成人| 亚洲激情五月| 国产国产精品| 日韩高清中文字幕一区二区| 精品亚洲免a| 国产亚洲精品美女久久| 久久午夜影视| 久久99伊人| 欧美日韩国产传媒| 99国产精品自拍| 亚洲婷婷在线| 久久久久99| 亚洲黄页一区| 亚洲激情中文在线| 免费国产亚洲视频| 视频在线在亚洲| 亚洲精品系列| 亚洲免费专区| 一区二区不卡| 日本在线成人| 日韩精品视频在线看| 国产精品亚洲片在线播放| 亚洲精品大片| 香蕉人人精品| 欧美成人亚洲| 9国产精品视频| 亚洲精品四区| 日韩综合一区二区| 麻豆精品新av中文字幕| 欧美国产专区| 国产精品欧美三级在线观看| 亚洲视频电影在线| 国产成人精品亚洲日本在线观看| 久久精品欧美一区| 国内精品美女在线观看| 国产suv精品一区| 91免费精品| 久久不见久久见中文字幕免费| 国产精品视频一区二区三区综合 | 国产一区日韩欧美| 美女网站一区| 欧美日韩激情在线一区二区三区| 免费看精品久久片| 日韩在线麻豆| 精品三级在线观看视频| 高清日韩中文字幕| 中文久久精品| 在线看片日韩| 亚洲精品无播放器在线播放| 欧美成a人片免费观看久久五月天| 国产欧美一区二区三区精品观看| 精品一区av| 群体交乱之放荡娇妻一区二区| 午夜久久黄色| 日韩影片在线观看| 国产情侣一区在线| 中文字幕系列一区| 美女日韩在线中文字幕| 九九九精品视频| 欧美日韩一二三四| 婷婷精品在线| 久久香蕉网站| 久久精品播放| 亚洲免费福利一区| 麻豆精品新av中文字幕| 99视频+国产日韩欧美| 亚洲天堂日韩在线| 久久狠狠久久| 免费看av不卡| 国产美女一区| 国产精品99久久精品| 欧美不卡视频| 国产一区精品福利| 蘑菇福利视频一区播放| 激情中国色综合| 91成人网在线观看|