文档目录
重要

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

TiDB v5.0 是 TiDB 数据库的最新稳定主版本,如无特殊需求,建议使用该版本。点击此处查看 TiDB v5.0 文档。

COMMIT

COMMIT 语句用于在 TiDB 服务器内部提交事务。

在不使用 BEGINSTART TRANSACTION 语句的情况下,TiDB 中每一个查询语句本身也会默认作为事务处理,自动提交,确保了与 MySQL 的兼容。

语法图

CommitStmt:

CommitStmt

示例

mysql> CREATE TABLE t1 (a int NOT NULL PRIMARY KEY);
Query OK, 0 rows affected (0.12 sec)

mysql> START TRANSACTION;
Query OK, 0 rows affected (0.00 sec)

mysql> INSERT INTO t1 VALUES (1);
Query OK, 1 row affected (0.00 sec)

mysql> COMMIT;
Query OK, 0 rows affected (0.01 sec)

MySQL 兼容性

  • TiDB 2.1 使用乐观事务模型。在乐观事务模型下,需要考虑到修改的行被另一个事务修改因此可能导致 COMMIT 语句执行失败的情况。后续 TiDB 版本支持使用悲观事务模型。
  • 默认情况下,UNIQUEPRIMARY KEY 约束检查将延迟直至语句提交。可通过设置 tidb_constraint_check_in_place=TRUE 来改变该行为。

另请参阅