次のようなテーブルを作成します
このステートメントは、データをコピーせずに、既存のテーブルの定義をコピーします。
あらすじ
- CreateTableLikeStmt
- OptTemporary
- LikeTableWithOrWithoutParen
- OnCommitOpt
CreateTableLikeStmt ::=
'CREATE' OptTemporary 'TABLE' IfNotExists TableName LikeTableWithOrWithoutParen OnCommitOpt
OptTemporary ::=
( 'TEMPORARY' | ('GLOBAL' 'TEMPORARY') )?
LikeTableWithOrWithoutParen ::=
'LIKE' TableName
| '(' 'LIKE' TableName ')'
OnCommitOpt ::=
('ON' 'COMMIT' 'DELETE' 'ROWS')?
例
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の互換性
TiDB のCREATE TABLE LIKE
ステートメントは MySQL と完全な互換性があります。互換性の違いが見つかった場合は、 バグを報告 .