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 等操作才被纳入该事务范围。
启科网络商城系统由启科网络技术开发团队完全自主开发,使用国内最流行高效的PHP程序语言,并用小巧的MySql作为数据库服务器,并且使用Smarty引擎来分离网站程序与前端设计代码,让建立的网站可以自由制作个性化的页面。 系统使用标签作为数据调用格式,网站前台开发人员只要简单学习系统标签功能和使用方法,将标签设置在制作的HTML模板中进行对网站数据、内容、信息等的调用,即可建设出美观、个性的网站。
提交或回滚事务
事务开启后,必须显式结束:
- 成功保存更改:
COMMIT; - 放弃所有更改:
ROLLBACK;
若未执行 COMMIT 或 ROLLBACK,事务会一直保持打开状态,可能占用锁资源、影响并发性能。
自动提交恢复与注意事项
事务结束后,autocommit 仍为 0,后续 SQL 仍处于事务模式,除非重新设为 1:
- 恢复自动提交:
SET autocommit = 1; - 事务只对当前会话生效,不影响其他连接
- 只有 InnoDB、NDB 等支持事务的存储引擎才真正支持事务;MyISAM 不支持









