COMMIT
COMMIT
语句用于在 TiDB 服务器内部提交事务。
在不使用 BEGIN
或 START TRANSACTION
语句的情况下,TiDB 中每一个查询语句本身也会默认作为事务处理,自动提交,确保了与 MySQL 的兼容。
语法图
CommitStmt:
示例
CREATE TABLE t1 (a int NOT NULL PRIMARY KEY);
Query OK, 0 rows affected (0.12 sec)
START TRANSACTION;
Query OK, 0 rows affected (0.00 sec)
INSERT INTO t1 VALUES (1);
Query OK, 1 row affected (0.00 sec)
COMMIT;
Query OK, 0 rows affected (0.01 sec)
MySQL 兼容性
- TiDB 3.0.8 及更新版本默认使用悲观事务模型。在乐观事务模型下,需要考虑到修改的行被另一个事务修改因此可能导致
COMMIT
语句执行失败的情况。 - 启用乐观事务模型后,
UNIQUE
和PRIMARY KEY
约束检查将延迟直至语句提交。当COMMIT
语句失败时,这可能导致其他问题。可通过设置tidb_constraint_check_in_place=TRUE
来改变该行为。