START TRANSACTION, COMMIT, and ROLLBACK

https://dev.mysql.com/doc/refman/5.7/en/commit.html

复制代码
START TRANSACTION
    [transaction_characteristic [, transaction_characteristic] ...]

transaction_characteristic: {
    WITH CONSISTENT SNAPSHOT
  | READ WRITE
  | READ ONLY
}

BEGIN [WORK]
COMMIT [WORK] [AND [NO] CHAIN] [[NO] RELEASE]
ROLLBACK [WORK] [AND [NO] CHAIN] [[NO] RELEASE]
SET autocommit = {0 | 1}
复制代码

 

关闭自动提交,使用START TRANSACTION statement:

START TRANSACTION;
SELECT @A:=SUM(salary) FROM table1 WHERE type=1;
UPDATE table2 SET summary=@A WHERE type=1;
COMMIT;

 

To disable autocommit mode explicitly, use the following statement:

SET autocommit=0;

 

Statements That Cannot Be Rolled Back

有些语句不能被回滚,总体上来说,包括数据定义语言(DDL),比如说那些数据create 或者drop databases,还有那些create,drop,alter tables or stored routines.

你必须的保证你的事务中不包含这些语句。如果在事务中前面的语句不能回滚,后面的其他语句也将发生错误,将会造成整个事务的不能回滚。

 

posted @   wongchaofan  阅读(100)  评论(0编辑  收藏  举报
编辑推荐:
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
· 没有源码,如何修改代码逻辑?
阅读排行:
· 分享4款.NET开源、免费、实用的商城系统
· 全程不用写代码,我用AI程序员写了一个飞机大战
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 记一次.NET内存居高不下排查解决与启示
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了
点击右上角即可分享
微信分享提示