CREATE TABLE
CREATE TABLE 语句用于在当前所选数据库中创建新表,与 MySQL 中 CREATE TABLE 语句的行为类似。另可参阅单独的 CREATE TABLE LIKE 文档。
语法图
- CreateTableStmt
- OptTemporary
- IfNotExists
- TableName
- TableElementListOpt
- TableElementList
- TableElement
- ColumnDef
- ColumnOptionListOpt
- ColumnOptionList
- ColumnOption
- Constraint
- IndexDef
- KeyPartList
- KeyPart
- IndexOption
- ForeignKeyDef
- ReferenceOption
- CreateTableOptionListOpt
- PartitionOpt
- DuplicateOpt
- TableOptionList
- TableOption
- OnCommitOpt
- PlacementPolicyOption
- DefaultValueExpr
- BuiltinFunction
- NowSymOptionFractionParentheses
- NowSymOptionFraction
- NextValueForSequenceParentheses
- NextValueForSequence
TiDB 支持以下 table_option。TiDB 会解析并忽略其他 table_option 参数,例如 AVG_ROW_LENGTH、CHECKSUM、COMPRESSION、CONNECTION、DELAY_KEY_WRITE、ENGINE、KEY_BLOCK_SIZE、MAX_ROWS、MIN_ROWS、ROW_FORMAT 和 STATS_PERSISTENT。
| 参数 | 含义 | 举例 |
|---|---|---|
AUTO_INCREMENT | 自增字段初始值 | AUTO_INCREMENT = 5 |
SHARD_ROW_ID_BITS | 用来设置隐式 _tidb_rowid 的分片数量的 bit 位数 | SHARD_ROW_ID_BITS = 4 |
PRE_SPLIT_REGIONS | 用来在建表时预先均匀切分 2^(PRE_SPLIT_REGIONS) 个 Region | PRE_SPLIT_REGIONS = 4 |
AUTO_ID_CACHE | 用来指定 Auto ID 在 TiDB 实例中 Cache 的大小,默认情况下 TiDB 会根据 Auto ID 分配速度自动调整 | AUTO_ID_CACHE = 200 |
AUTO_RANDOM_BASE | 用来指定 AutoRandom 自增部分的初始值,该参数可以被认为属于内部接口的一部分,对于用户而言请忽略 | AUTO_RANDOM_BASE = 0 |
CHARACTER SET | 指定该表所使用的字符集 | CHARACTER SET = 'utf8mb4' |
COLLATE | 指定该表所使用的字符集排序规则 | COLLATE = 'utf8mb4_bin' |
COMMENT | 注释信息 | COMMENT = 'comment info' |
AFFINITY | 为表或分区开启亲和性调度。非分区表可设置为 'table',分区表可设置为 'partition'。设置为 'none' 或留空可关闭亲和性调度 | AFFINITY = 'table' |
注意
- 在 TiDB 配置文件中,
split-table默认开启。当该配置项开启时,建表操作会为每个表建立单独的 Region,详情参见 TiDB 配置文件描述。- 使用
AFFINITY时,当前不支持对该表进行分区方案变更(如添加、删除、重组或交换分区),也不支持在临时表或视图上设置该选项。
示例
创建一张简单表并插入一行数据:
CREATE TABLE t1 (a int);
DESC t1;
SHOW CREATE TABLE t1\G
INSERT INTO t1 (a) VALUES (1);
SELECT * FROM t1;mysql> drop table if exists t1;
Query OK, 0 rows affected (0.23 sec)
mysql> CREATE TABLE t1 (a int);
Query OK, 0 rows affected (0.09 sec)
mysql> DESC t1;
+-------+------+------+------+---------+-------+
| Field | Type | Null | Key | Default | Extra |
+-------+------+------+------+---------+-------+
| a | int | YES | | NULL | |
+-------+------+------+------+---------+-------+
1 row in set (0.00 sec)
mysql> SHOW CREATE TABLE t1\G
*************************** 1. row ***************************
Table: t1
Create Table: CREATE TABLE `t1` (
`a` int DEFAULT NULL
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_bin
1 row in set (0.00 sec)
mysql> INSERT INTO t1 (a) VALUES (1);
Query OK, 1 row affected (0.03 sec)
mysql> SELECT * FROM t1;
+------+
| a |
+------+
| 1 |
+------+
1 row in set (0.00 sec)删除一张表。如果该表不存在,就建一张表:
DROP TABLE IF EXISTS t1;
CREATE TABLE IF NOT EXISTS t1 (
id BIGINT NOT NULL PRIMARY KEY auto_increment,
b VARCHAR(200) NOT NULL
);
DESC t1;mysql> DROP TABLE IF EXISTS t1;
Query OK, 0 rows affected (0.22 sec)
mysql> CREATE TABLE IF NOT EXISTS t1 (
id BIGINT NOT NULL PRIMARY KEY auto_increment,
b VARCHAR(200) NOT NULL
);
Query OK, 0 rows affected (0.08 sec)
mysql> DESC t1;
+-------+--------------+------+------+---------+----------------+
| Field | Type | Null | Key | Default | Extra |
+-------+--------------+------+------+---------+----------------+
| id | bigint | NO | PRI | NULL | auto_increment |
| b | varchar(200) | NO | | NULL | |
+-------+--------------+------+------+---------+----------------+
2 rows in set (0.00 sec)MySQL 兼容性
- 支持除空间类型以外的所有数据类型。
- 为了兼容 MySQL,TiDB 在语法上支持
HASH、BTREE和RTREE等索引类型,但会忽略它们。 - TiDB 支持解析
FULLTEXT语法,但不支持使用FULLTEXT索引。 - 为了与 MySQL 兼容,
index_col_name属性支持 length 选项,最大长度默认限制为 3072 字节。此长度限制可以通过配置项max-index-length更改,具体请参阅 TiDB 配置文件描述。 - 为了与 MySQL 兼容,TiDB 会解析但忽略
index_col_name属性的[ASC | DESC]索引排序选项。 COMMENT属性不支持WITH PARSER选项。- TiDB 在单个表中默认支持 1017 列,最大可支持 4096 列。InnoDB 中相应的数量限制为 1017 列,MySQL 中的硬限制为 4096 列。详情参阅 TiDB 使用限制。
- 分区表支持
HASH、RANGE、LIST和KEY分区类型。对于不支持的分区类型,TiDB 会报Warning: Unsupported partition type %s, treat as normal table错误,其中%s为不支持的具体分区类型。 - TiDB 对分区表进行了扩展。你可以指定
GLOBAL索引选项将PRIMARY KEY或UNIQUE INDEX设置为全局索引。该扩展与 MySQL 不兼容。