次のようなテーブルを作成

このステートメントは、データをコピーせずに、既存のテーブルの定義をコピーします。

あらすじ

CreateTableLikeStmt
CREATEOptTemporaryTABLEIfNotExistsTableNameLikeTableWithOrWithoutParenOnCommitOpt
OptTemporary
TEMPORARYGLOBALTEMPORARY
LikeTableWithOrWithoutParen
LIKETableName(LIKETableName)
OnCommitOpt
ONCOMMITDELETEROWS

mysql> CREATE TABLE t1 (a INT NOT NULL);
Query OK, 0 rows affected (0.13 sec)

mysql> INSERT INTO t1 VALUES (1),(2),(3),(4),(5);
Query OK, 5 rows affected (0.02 sec)
Records: 5  Duplicates: 0  Warnings: 0

mysql> SELECT * FROM t1;
+---+
| a |
+---+
| 1 |
| 2 |
| 3 |
| 4 |
| 5 |
+---+
5 rows in set (0.00 sec)

mysql> CREATE TABLE t2 LIKE t1;
Query OK, 0 rows affected (0.10 sec)

mysql> SELECT * FROM t2;
Empty set (0.00 sec)

分割前のリージョン

コピーするテーブルがPRE_SPLIT_REGIONS属性で定義されている場合、 CREATE TABLE LIKEステートメントを使用して作成されたテーブルはこの属性を継承し、新しいテーブルのリージョンは分割されます。 PRE_SPLIT_REGIONSの詳細については、 CREATE TABLEステートメントを参照してください。

MySQL の互換性

このステートメントは、MySQL と完全に互換性があると理解されています。互換性の違いは、GitHub で問題を介して報告されたにする必要があります。

こちらもご覧ください

エコシステム
TiDB
TiKV
TiFlash
TiSpark
Chaos Mesh
© 2023 PingCAP. All Rights Reserved.