1 MySQL的autocommit設(shè)置
MySQL默認(rèn)是開啟自動提交的,即每一條DML(增刪改)語句都會被作為一個單獨的事務(wù)進(jìn)行隱式提交。如果修改為關(guān)閉狀態(tài),則執(zhí)行DML語句之后要手動提交 才能生效。
查詢當(dāng)前會話的自動提交是否開啟:
mysql> show variables like 'autocommit';
+---------------+-------+
| Variable_name | Value |
+---------------+-------+
| autocommit | ON |
+---------------+-------+
查詢?nèi)值淖詣犹峤皇欠耖_啟:
mysql> show global variables like 'autocommit';
+---------------+-------+
| Variable_name | Value |
+---------------+-------+
| autocommit | ON |
+---------------+-------+
通過修改autocommit變量可以關(guān)閉和開啟操作
關(guān)閉當(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中對自動提交的控制
MySQL的JDBC驅(qū)動包 mysql-connector-java 會給會話的connection默認(rèn)開啟自動提交,譬如 mysql-connector-java-8.0.22版本的代碼:
//com.mysql.cj.protocol.a.NativeServerSession.java
private boolean autoCommit = true;
常用的數(shù)據(jù)庫連接池 如HikariCP,druid等,默認(rèn)也是開啟自動提交,會將connection的自動提交設(shè)置都改為true。
druid在初始化DataSource的時候設(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;
}
對于事務(wù)管理器PlatformTransactionManager管理的顯式事務(wù)(譬如@Transactional注解聲明)在 開啟事務(wù)時會關(guān)閉自動提交模式。 代碼如下:
@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)閉自動提交模
con.setAutoCommit(false);
}
.......
}
catch (Throwable ex) {
.......
}
}
總結(jié)
MySQL的autocommit模式默認(rèn)是打開狀態(tài),為了防止手動的DML操作導(dǎo)致失誤,生產(chǎn)環(huán)境可以設(shè)置為默認(rèn)關(guān)閉的狀態(tài)。一般的jdbc 連接池默認(rèn)都是開啟狀態(tài),而且是可配置的。顯式事務(wù)下會設(shè)置成關(guān)閉狀態(tài),單純的修改數(shù)據(jù)庫環(huán)境的autocommit不會對代碼的行為產(chǎn)生影響。
以上就是詳解MySQL與Spring的自動提交(autocommit)的詳細(xì)內(nèi)容,更多關(guān)于MySQL 自動提交(autocommit)的資料請關(guān)注腳本之家其它相關(guān)文章!
您可能感興趣的文章:- MySQL找出未提交事務(wù)的SQL實例淺析
- mysql實現(xiàn)事務(wù)的提交與回滾的實例詳解
- MySQL找出未提交事務(wù)信息的方法分享
- Mysql事務(wù)隔離級別之讀提交詳解
- 探究MySQL中索引和提交頻率對InnoDB表寫入速度的影響
- php將textarea數(shù)據(jù)提交到mysql出現(xiàn)很多空格的解決方法
- mysql實現(xiàn)事務(wù)的提交和回滾實例
- python連接mysql并提交mysql事務(wù)示例
- JSP+ MySQL中文亂碼問題post提交亂碼解決方案