📣
TiDB Cloud Essential 开放公测中。此页面由 AI 自动翻译,英文原文请见此处。

CREATE TABLE

该语句会在当前选定的数据库中创建一个新表。其行为与 MySQL 中的 CREATE TABLE 语句类似。

语法

CreateTableStmt
CREATEOptTemporaryTABLEIfNotExistsTableNameTableElementListOptCreateTableOptionListOptPartitionOptDuplicateOptAsOptCreateTableSelectOptLikeTableWithOrWithoutParenOnCommitOpt
OptTemporary
TEMPORARYGLOBALTEMPORARY
IfNotExists
IFNOTEXISTS
TableName
Identifier.Identifier
TableElementListOpt
(TableElementList)
TableElementList
TableElement,
TableElement
ColumnDefConstraint
ColumnDef
ColumnNameTypeSERIALColumnOptionListOpt
ColumnOptionListOpt
ColumnOption
ColumnOptionList
ColumnOption
ColumnOption
NOTNULLAUTO_INCREMENTPrimaryOptKEYGLOBALLOCALUNIQUEKEYGLOBALLOCALDEFAULTDefaultValueExprSERIALDEFAULTVALUEONUPDATENowSymOptionFractionCOMMENTstringLitConstraintKeywordOptCHECK(Expression)EnforcedOrNotOrNotNullOptGeneratedAlwaysAS(Expression)VirtualOrStoredReferDefCOLLATECollationNameCOLUMN_FORMATColumnFormatSTORAGEStorageMediaAUTO_RANDOMOptFieldLen
Constraint
IndexDefForeignKeyDef
IndexDef
INDEXKEYIndexName(KeyPartList)IndexOption
KeyPartList
KeyPart,
KeyPart
ColumnName(Length)ASCDESC(Expression)ASCDESC
IndexOption
COMMENTStringVISIBLEINVISIBLEUSINGTYPEBTREERTREEHASHGLOBALLOCAL
ForeignKeyDef
CONSTRAINTIdentifierFOREIGNKEYIdentifier(ColumnName,)REFERENCESTableName(ColumnName,)ONDELETEReferenceOptionONUPDATEReferenceOption
ReferenceOption
RESTRICTCASCADESETNULLSETDEFAULTNOACTION
CreateTableOptionListOpt
TableOptionList
PartitionOpt
PARTITIONBYPartitionMethodPartitionNumOptSubPartitionOptPartitionDefinitionListOpt
DuplicateOpt
IGNOREREPLACE
TableOptionList
TableOption,
TableOption
PartDefOptionDefaultKwdOptCharsetKwEqOptCharsetNameCOLLATEEqOptCollationNameAUTO_INCREMENTAUTO_ID_CACHEAUTO_RANDOM_BASEAVG_ROW_LENGTHCHECKSUMTABLE_CHECKSUMKEY_BLOCK_SIZEDELAY_KEY_WRITESHARD_ROW_ID_BITSPRE_SPLIT_REGIONSEqOptLengthNumCONNECTIONPASSWORDCOMPRESSIONEqOptstringLitRowFormatSTATS_PERSISTENTPACK_KEYSEqOptStatsPersistentValSTATS_AUTO_RECALCSTATS_SAMPLE_PAGESEqOptLengthNumDEFAULTSTORAGEMEMORYDISKSECONDARY_ENGINEEqOptNULLStringNameUNIONEqOpt(TableNameListOpt)ENCRYPTIONEqOptEncryptionOptTTLEqOptTimeColumnName+INTERVALExpressionTimeUnitTTLEnableEqOptONOFFTTLJobIntervalEqOptstringLitPlacementPolicyOption
OnCommitOpt
ONCOMMITDELETEROWS
PlacementPolicyOption
PLACEMENTPOLICYEqOptPolicyNamePLACEMENTPOLICYEqOptSETDEFAULT
DefaultValueExpr
NowSymOptionFractionParenthesesSignedLiteralNextValueForSequenceParenthesesBuiltinFunction
BuiltinFunction
(BuiltinFunction)identifier()identifier(ExpressionList)REPLACE(ExpressionList)
NowSymOptionFractionParentheses
(NowSymOptionFractionParentheses)NowSymOptionFraction
NowSymOptionFraction
NowSymNowSymFunc()NowSymFunc(NUM)CurdateSym()CURRENT_DATE
NextValueForSequenceParentheses
(NextValueForSequenceParentheses)NextValueForSequence
NextValueForSequence
NEXTVALUEforKwdTableNameNEXTVAL(TableName)

下表为支持的 table_options。其他选项如 AVG_ROW_LENGTHCHECKSUMCOMPRESSIONCONNECTIONDELAY_KEY_WRITEENGINEKEY_BLOCK_SIZEMAX_ROWSMIN_ROWSROW_FORMATSTATS_PERSISTENT 仅解析但会被忽略。

选项描述示例
AUTO_INCREMENT自增字段的初始值AUTO_INCREMENT = 5
SHARD_ROW_ID_BITS设置隐式 _tidb_rowid 分片的位数SHARD_ROW_ID_BITS = 4
PRE_SPLIT_REGIONS创建表时预先分裂出 2^(PRE_SPLIT_REGIONS) 个 RegionPRE_SPLIT_REGIONS = 4
AUTO_ID_CACHE设置 TiDB 实例中自增 ID 的缓存大小。默认情况下,TiDB 会根据自增 ID 的分配速度自动调整该大小AUTO_ID_CACHE = 200
AUTO_RANDOM_BASE设置 auto_random 的初始递增部分的值。该选项可视为内部接口的一部分,用户可忽略此参数AUTO_RANDOM_BASE = 0
CHARACTER SET指定表的 字符集CHARACTER SET = 'utf8mb4'
COMMENT注释信息COMMENT = 'comment info'

示例

创建一个简单的表并插入一行数据:

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 兼容性

  • 支持除空间类型外的所有数据类型。

  • TiDB 为了兼容 MySQL,语法上接受如 HASHBTREERTREE 等索引类型,但会忽略这些类型。

  • TiDB 自建版和 TiDB Cloud 专属集群支持解析 FULLTEXT 语法,但不支持使用 FULLTEXT 索引。

  • 分区表 中,将 PRIMARY KEYUNIQUE INDEX 设置为 全局索引(使用 GLOBAL 索引选项)是 TiDB 的扩展功能,不兼容 MySQL。

  • 为了兼容性,index_col_name 属性支持长度选项,默认最大长度限制为 3072 字节。
  • index_col_name 中的 [ASC | DESC] 目前会被解析但被忽略(与 MySQL 5.7 行为兼容)。
  • COMMENT 属性不支持 WITH PARSER 选项。
  • TiDB 默认支持单表 1017 列,最多支持 4096 列。InnoDB 中的对应限制为 1017 列,MySQL 的硬性上限为 4096 列。详情参见 TiDB 限制
  • TiDB 支持 HASHRANGELISTKEY 分区类型。对于不支持的分区类型,TiDB 会返回 Warning: Unsupported partition type %s, treat as normal table,其中 %s 为具体的不支持分区类型。

另请参阅

文档内容是否有帮助?