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

P粉602998670
发布: 2025-12-21 19:24:01
原创
693人浏览过
MySQL事务默认自动提交,需先SET autocommit=0关闭自动提交,再用START TRANSACTION显式开启;之后执行DML操作,最后用COMMIT或ROLLBACK结束事务。

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

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商城系统
启科网络PHP商城系统

启科网络商城系统由启科网络技术开发团队完全自主开发,使用国内最流行高效的PHP程序语言,并用小巧的MySql作为数据库服务器,并且使用Smarty引擎来分离网站程序与前端设计代码,让建立的网站可以自由制作个性化的页面。 系统使用标签作为数据调用格式,网站前台开发人员只要简单学习系统标签功能和使用方法,将标签设置在制作的HTML模板中进行对网站数据、内容、信息等的调用,即可建设出美观、个性的网站。

启科网络PHP商城系统 0
查看详情 启科网络PHP商城系统

提交或回滚事务

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

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

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

自动提交恢复与注意事项

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

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

以上就是如何在mysql中开启事务_mysql事务开启语法的详细内容,更多请关注php中文网其它相关文章!

相关标签:
最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号