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

4次阅读

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

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

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

MySQL 创建表不能只写字段名,每个字段都必须明确指定数据类型(如 VARCHAR(255)intDATETIME),否则会报错 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 必须显式指定才可靠

不加 ENGINECHARSET 时,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 仅对 TIMESTAMPDATETIME 有效
  • DEFAULT NULL 对可空字段冗余,可直接省略;对非空字段无效
  • 字符串类型建议用 DEFAULT '' 而非 DEFAULT NULL,避免后续 WHERE name = ''WHERE name IS NULL 混淆

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

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

  • 外键需两端字段类型严格一致(包括有无符号、长度),且被引用列必须有索引(通常是主键或唯一键)
  • 高频查询的 WHERE 条件字段,如 user_idstatus,应在建表时用 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);

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

text=ZqhQzanResources