COMMIT

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

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

语法图

CommitStmt:

commit\_1.png

示例

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 兼容性

  • 在 MySQL 中,除了有多个 primary 的群组复制以外,COMMIT 语句通常不会导致错误。相比之下,TiDB 使用乐观并发控制,冲突可能导致 COMMIT 返回错误。
  • 默认情况下,UNIQUEPRIMARY KEY 约束检查将延迟直至语句提交。可通过设置 tidb_constraint_check_in_place=TRUE 来改变该行为。

另请参阅

  • START TRANSACTION
  • ROLLBACK
  • BEGIN
  • Lazy checking of constraints

看完两件小事

如果你觉得这篇文章对你挺有启发,我想请你帮我两个小忙:

  1. 关注我们的 GitHub 博客,让我们成为长期关系
  2. 把这篇文章分享给你的朋友 / 交流群,让更多的人看到,一起进步,一起成长!
  3. 关注公众号 「方志朋」,公众号后台回复「资源」 免费领取我精心整理的前端进阶资源教程

JS中文网是中国领先的新一代开发者社区和专业的技术媒体,一个帮助开发者成长的社区,目前已经覆盖和服务了超过 300 万开发者,你每天都可以在这里找到技术世界的头条内容。欢迎热爱技术的你一起加入交流与学习,JS中文网的使命是帮助开发者用代码改变世界

results matching ""

    No results matching ""