mysql如何创建表_mysql表创建语法说明

来源:这里教程网 时间:2026-02-28 20:46:51 作者:

CREATE TABLE 基本语法结构必须写全字段类型和约束

MySQL 创建表不能只写字段名,每个字段都必须明确指定数据类型(如

VARCHAR(255)
INT
DATETIME
),否则会报错
ERROR 1167: The used table type doesn't support BLOB/TEXT columns
或更早的语法错误。主键、自增、非空等常见约束也得显式声明,MySQL 不会自动补全。

常见误写:

CREATE TABLE user (id, name);
→ 错误:缺少类型
正确写法示例:
CREATE TABLE user (id INT PRIMARY KEY AUTO_INCREMENT, name VARCHAR(100) NOT NULL);

ENGINE 和 CHARSET 必须显式指定才可靠

不加

ENGINE
CHARSET
时,MySQL 会按服务器默认值(可能是
MyISAM
或旧版
latin1
)建表,容易引发事务不支持、中文乱码、并发性能差等问题。生产环境务必显式声明。

ENGINE=InnoDB
是当前默认且推荐的存储引擎,支持事务、外键、行锁
CHARSET=utf8mb4
才能完整支持 emoji 和所有 Unicode 字符;
utf8
在 MySQL 中实际是
utf8mb3
,已弃用
配套加上
COLLATE=utf8mb4_unicode_ci
可避免排序和比较异常

完整建表语句示例:

CREATE TABLE article (id BIGINT PRIMARY KEY AUTO_INCREMENT, title VARCHAR(200) NOT NULL, content TEXT, created_at DATETIME DEFAULT CURRENT_TIMESTAMP) ENGINE=InnoDB CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci;

DEFAULT 值要匹配字段类型,否则插入失败

给字段设

DEFAULT
时,值必须与字段类型兼容。比如
INT
字段不能设
DEFAULT 'abc'
DATETIME
不能设
DEFAULT 0
(除非 SQL mode 允许,但不建议依赖)。

DEFAULT CURRENT_TIMESTAMP
仅对
TIMESTAMP
DATETIME
有效
DEFAULT NULL
对可空字段冗余,可直接省略;对非空字段无效
字符串类型建议用
DEFAULT ''
而非
DEFAULT NULL
,避免后续
WHERE name = ''
WHERE name IS NULL
混淆

外键和索引需在建表时一并定义,后期添加成本高

虽然可以用

ALTER TABLE
加外键或索引,但涉及大表时会锁表、阻塞写入,线上操作风险高。建表阶段就规划好更稳妥。

外键需两端字段类型严格一致(包括有无符号、长度),且被引用列必须有索引(通常是主键或唯一键) 高频查询的
WHERE
条件字段,如
user_id
status
,应在建表时用
INDEX
显式声明
联合索引顺序很重要:例如查询常带
WHERE category_id = ? AND status = ?
,应建
INDEX(category_id, status)
,反过来效果差

带外键的示例:

CREATE TABLE order_item (id BIGINT PRIMARY KEY, order_id BIGINT NOT NULL, product_id BIGINT NOT NULL, quantity INT, FOREIGN KEY (order_id) REFERENCES `order`(id) ON DELETE CASCADE);

外键约束名、索引名、字段注释这些细节看着小,但上线后查问题、做迁移、加监控时,缺一个都可能多花半小时定位。别省那几行代码。

相关推荐