MySQL建表必须显式声明字段类型、约束、ENGINE、CHARSET及COLLATE;DEFAULT值须匹配类型;外键和索引宜建表时定义,并注意字段类型一致与联合索引顺序。

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);










