取引開始
このステートメントは、TiDB 内で新しいトランザクションを開始します。これは、ステートメントBEGIN
に似ています。
START TRANSACTION
ステートメントがない場合、すべてのステートメントはデフォルトで独自のトランザクションで自動コミットされます。この動作により、MySQL の互換性が確保されます。
あらすじ
BeginTransactionStmt:
- BeginTransactionStmt
- AsOfClause
BeginTransactionStmt ::=
'BEGIN' ( 'PESSIMISTIC' | 'OPTIMISTIC' )?
| 'START' 'TRANSACTION' ( 'READ' ( 'WRITE' | 'ONLY' ( ( 'WITH' 'TIMESTAMP' 'BOUND' TimestampBound )? | AsOfClause ) ) | 'WITH' 'CONSISTENT' 'SNAPSHOT' | 'WITH' 'CAUSAL' 'CONSISTENCY' 'ONLY' )?
AsOfClause ::=
( 'AS' 'OF' 'TIMESTAMP' Expression)
例
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 との互換性のために解析されますが、書き込み操作は引き続き許可されます。