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