PingKai Logo下载

ROLLBACK

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

语法图

RollbackStmt
ROLLBACK CompletionTypeWithinTransaction
CompletionTypeWithinTransaction
AND CHAIN NO RELEASE NO CHAIN NO RELEASE NO RELEASE

示例

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

另请参阅