如何在mysql中开启事务_mysql事务开启语法

MySQL事务默认自动提交,需先SET autocommit=0关闭自动提交,再用START TRANSACTION显式开启;之后执行DML操作,最后用COMMIT或ROLLBACK结束事务。

MySQL 中事务默认是自动提交的,要开启手动事务控制,需先关闭自动提交模式,再用 START TRANSACTION(或 BEGIN)显式启动事务。

关闭自动提交(关键前提)

MySQL 默认每条 SQL 语句都自动提交。开启事务前必须确保当前会话的 autocommit 为 0:

  • 查看当前设置:SELECT @@autocommit;(返回 1 表示开启,0 表示关闭)
  • 临时关闭(仅对当前会话有效):SET autocommit = 0;
  • 也可在连接时指定:mysql --init-command="SET autocommit=0;" -u user -p

显式开启事务

关闭 autocommit 后,使用以下任一语法开始一个新事务:

  • START TRANSACTION;(推荐,SQL 标准语法)
  • BEGIN;(等价于 START TRANSACTION,但语义稍弱)
  • BEGIN WORK;(同上,兼容旧写法)

注意:执行这些命令本身不会改变数据,只是标记事务起点;后续的 INSERT/UPDATE/DELETE 等操作才被纳入该事务范围。

提交或回滚事务

事务开启后,必须显式结束:

  • 成功保存更改:COMMIT;
  • 放弃所有更改:ROLLBACK;

若未执行 COMMIT 或 ROLLBACK,事务会一直保持打开状态,可能占用锁资源、影响并发性能。

自动提交恢复与注意事项

事务结束后,autocommit 仍为 0,后续 SQL 仍处于事务模式,除非重新设为 1:

  • 恢复自动提交:SET autocommit = 1;
  • 事务只对当前会话生效,不影响其他连接
  • 只有 InnoDB、NDB 等支持事务的存储引擎才真正支持事务;MyISAM 不支持