主頁(yè) > 知識(shí)庫(kù) > 詳解MySQL與Spring的自動(dòng)提交(autocommit)

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

熱門標(biāo)簽:百應(yīng)電話機(jī)器人優(yōu)勢(shì) 南昌三維地圖標(biāo)注 曲靖移動(dòng)外呼系統(tǒng)公司 啥是企業(yè)400電話辦理 電話外呼系統(tǒng)改號(hào) 外呼系統(tǒng)打電話上限是多少 怎樣在地圖標(biāo)注銷售區(qū)域 武漢網(wǎng)絡(luò)外呼系統(tǒng)服務(wù)商 地圖標(biāo)注費(fèi)用是多少

1 MySQL的autocommit設(shè)置

MySQL默認(rèn)是開啟自動(dòng)提交的,即每一條DML(增刪改)語(yǔ)句都會(huì)被作為一個(gè)單獨(dú)的事務(wù)進(jìn)行隱式提交。如果修改為關(guān)閉狀態(tài),則執(zhí)行DML語(yǔ)句之后要手動(dòng)提交 才能生效。
查詢當(dāng)前會(huì)話的自動(dòng)提交是否開啟:

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

查詢?nèi)值淖詣?dòng)提交是否開啟:

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

通過(guò)修改autocommit變量可以關(guān)閉和開啟操作

關(guān)閉當(dāng)前會(huì)話的自動(dòng)提交模式
mysql> set autocommit=0;

 
mysql> show variables like 'autocommit';
+---------------+-------+
| Variable_name | Value |
+---------------+-------+
| autocommit  | OFF  |
+---------------+-------+

 全局的autocommit還是開啟狀態(tài)
mysql> show global variables like 'autocommit';
+---------------+-------+
| Variable_name | Value |
+---------------+-------+
| autocommit  | ON  |
+---------------+-------+

 
 關(guān)閉全局的autocommit
mysql> set global autocommit=0;

 
mysql> show global variables like 'autocommit';
+---------------+-------+
| Variable_name | Value |
+---------------+-------+
| autocommit  | OFF  |
+---------------+-------+

如果想要MySQL服務(wù)重啟之后仍能生效,需要設(shè)置系統(tǒng)環(huán)境變量。MySQL5.7 在cnf配置文件中[mysqld]下面設(shè)置autocommit的值。

[mysqld]
...
autocommit=0

Spring中對(duì)自動(dòng)提交的控制

MySQL的JDBC驅(qū)動(dòng)包 mysql-connector-java 會(huì)給會(huì)話的connection默認(rèn)開啟自動(dòng)提交,譬如 mysql-connector-java-8.0.22版本的代碼:

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

常用的數(shù)據(jù)庫(kù)連接池 如HikariCP,druid等,默認(rèn)也是開啟自動(dòng)提交,會(huì)將connection的自動(dòng)提交設(shè)置都改為true。
druid在初始化DataSource的時(shí)候設(shè)置connection的autocommit為true。代碼如下:

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

HikariCP 初始化DataSource的默認(rèn)配置 中autocommit也是true:

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

對(duì)于事務(wù)管理器PlatformTransactionManager管理的顯式事務(wù)(譬如@Transactional注解聲明)在 開啟事務(wù)時(shí)會(huì)關(guān)閉自動(dòng)提交模式。 代碼如下:

	@Override
	protected 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");
				}
                //關(guān)閉自動(dòng)提交模
                con.setAutoCommit(false);
			}

      		.......
		}

		catch (Throwable ex) {
     		.......
		}
	}

總結(jié)

MySQL的autocommit模式默認(rèn)是打開狀態(tài),為了防止手動(dòng)的DML操作導(dǎo)致失誤,生產(chǎn)環(huán)境可以設(shè)置為默認(rèn)關(guān)閉的狀態(tài)。一般的jdbc 連接池默認(rèn)都是開啟狀態(tài),而且是可配置的。顯式事務(wù)下會(huì)設(shè)置成關(guān)閉狀態(tài),單純的修改數(shù)據(jù)庫(kù)環(huán)境的autocommit不會(huì)對(duì)代碼的行為產(chǎn)生影響。

以上就是詳解MySQL與Spring的自動(dòng)提交(autocommit)的詳細(xì)內(nèi)容,更多關(guān)于MySQL 自動(dòng)提交(autocommit)的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!

您可能感興趣的文章:
  • MySQL找出未提交事務(wù)的SQL實(shí)例淺析
  • mysql實(shí)現(xiàn)事務(wù)的提交與回滾的實(shí)例詳解
  • MySQL找出未提交事務(wù)信息的方法分享
  • Mysql事務(wù)隔離級(jí)別之讀提交詳解
  • 探究MySQL中索引和提交頻率對(duì)InnoDB表寫入速度的影響
  • php將textarea數(shù)據(jù)提交到mysql出現(xiàn)很多空格的解決方法
  • mysql實(shí)現(xiàn)事務(wù)的提交和回滾實(shí)例
  • python連接mysql并提交mysql事務(wù)示例
  • JSP+ MySQL中文亂碼問(wèn)題post提交亂碼解決方案

標(biāo)簽:黑河 錦州 荊州 資陽(yáng) 甘南 滄州 吉林 隨州

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《詳解MySQL與Spring的自動(dòng)提交(autocommit)》,本文關(guān)鍵詞  詳解,MySQL,與,Spring,的,自動(dòng),;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《詳解MySQL與Spring的自動(dòng)提交(autocommit)》相關(guān)的同類信息!
  • 本頁(yè)收集關(guān)于詳解MySQL與Spring的自動(dòng)提交(autocommit)的相關(guān)信息資訊供網(wǎng)民參考!
  • 企业400电话

    智能AI客服机器人
    15000

    在线订购

    合计11份范本:公司章程+合伙协议+出资协议+合作协议+股权转让协议+增资扩股协议+股权激励+股东会决议+董事会决议

    推薦文章