重要

你正在查看 TiDB 数据库的较旧版本 (TiDB v5.4) 的文档。

如无特殊需求,建议使用 TiDB 数据库的最新 LTS 版本

ROLLBACK

ROLLBACK 语句用于还原 TiDB 内当前事务中的所有更改,作用与 COMMIT 语句相反。

语法图

RollbackStmt
ROLLBACKCompletionTypeWithinTransaction
CompletionTypeWithinTransaction
ANDCHAINNORELEASENOCHAINNORELEASENORELEASE

示例

CREATE TABLE t1 (a INT NOT NULL PRIMARY KEY);
Query OK, 0 rows affected (0.12 sec)
BEGIN;
Query OK, 0 rows affected (0.00 sec)
INSERT INTO t1 VALUES (1);
Query OK, 1 row affected (0.00 sec)
ROLLBACK;
Query OK, 0 rows affected (0.01 sec)
SELECT * FROM t1;
Empty set (0.01 sec)

MySQL 兼容性

  • TiDB 不支持 savepoint 或 ROLLBACK TO SAVEPOINT 语法。
  • TiDB 解析但忽略 ROLLBACK AND [NO] RELEASE 语法。在 MySQL 中,使用该语法可在回滚事务后立即断开客户端会话。在 TiDB 中,建议使用客户端程序的 mysql_close() 来实现该功能。
  • TiDB 解析但忽略 ROLLBACK AND [NO] CHAIN 语法。在 MySQL 中,使用该语法可在回滚当前事务时立即以相同的隔离级别开启新事务。在 TiDB 中,推荐直接开启新事务。

另请参阅

文档内容是否有帮助?