取引開始

このステートメントは、TiDB 内で新しいトランザクションを開始します。これは、ステートメントBEGINに似ています。

START TRANSACTIONステートメントがない場合、すべてのステートメントはデフォルトで独自のトランザクションで自動コミットされます。この動作により、MySQL の互換性が確保されます。

あらすじ

BeginTransactionStmt:

BeginTransactionStmt
BEGINPESSIMISTICOPTIMISTICSTARTTRANSACTIONREADWRITEONLYWITHTIMESTAMPBOUNDTimestampBoundAsOfClauseWITHCONSISTENTSNAPSHOTWITHCAUSALCONSISTENCYONLY
AsOfClause
ASOFTIMESTAMPExpression

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 の互換性

  • START TRANSACTIONは、TiDB 内ですぐにトランザクションを開始します。これは、 START TRANSACTIONが遅延してトランザクションを作成する MySQL とは異なります。しかし、TiDB のSTART TRANSACTIONは MySQL のSTART TRANSACTION WITH CONSISTENT SNAPSHOTと同等です。

  • ステートメントSTART TRANSACTION READ ONLYは、MySQL との互換性のために解析されますが、書き込み操作は引き続き許可されます。

こちらもご覧ください