MySQL实际项目中常用的 DDL 模板

✅ 一、建表模板(带审计字段 + 索引)

sql 复制代码
CREATE TABLE `hot_campaign` (
    `id` BIGINT NOT NULL AUTO_INCREMENT COMMENT '主键',
    `campaign_name` VARCHAR(64) NOT NULL COMMENT '活动名称',
    `site` VARCHAR(32) NOT NULL COMMENT '站点',
    `status` TINYINT NOT NULL DEFAULT 1 COMMENT '状态:1启用 0停用',
    `created_at` DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
    `created_by` VARCHAR(16) DEFAULT NULL COMMENT '创建人工号',
    `updated_at` DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间',
    `updated_by` VARCHAR(16) DEFAULT NULL COMMENT '更新人工号',

    PRIMARY KEY (`id`),
    KEY `idx_site` (`site`),
    KEY `idx_status` (`status`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COMMENT='营销活动表';

✅ 二、修改表结构(ADD / DROP / CHANGE / MODIFY)

1)新增字段

sql 复制代码
ALTER TABLE `hot_campaign`
ADD COLUMN `last_updated_staff` VARCHAR(16) DEFAULT NULL COMMENT '最后更新人工号';

2)删除字段

sql 复制代码
ALTER TABLE `hot_campaign`
DROP COLUMN `last_updated_staff`;

3)修改字段类型(MODIFY)

仅修改类型,不改字段名

sql 复制代码
ALTER TABLE `hot_campaign`
MODIFY COLUMN `campaign_name` VARCHAR(128) NOT NULL COMMENT '活动名称';

4)修改字段名 + 字段类型(CHANGE)

sql 复制代码
ALTER TABLE `hot_campaign`
CHANGE COLUMN `status` `campaign_status` TINYINT NOT NULL DEFAULT 1 COMMENT '活动状态';

5)修改字段默认值

sql 复制代码
ALTER TABLE `hot_campaign`
ALTER COLUMN `status` SET DEFAULT 1;

✅ 三、索引相关(INDEX / UNIQUE / DROP)

1)新增普通索引

sql 复制代码
ALTER TABLE `hot_campaign`
ADD INDEX `idx_name` (`campaign_name`);

2)新增联合索引

sql 复制代码
ALTER TABLE `hot_campaign`
ADD INDEX `idx_site_status` (`site`, `status`);

3)新增唯一索引

sql 复制代码
ALTER TABLE `hot_campaign`
ADD UNIQUE INDEX `uk_site_name` (`site`, `campaign_name`);

4)删除索引

sql 复制代码
ALTER TABLE `hot_campaign`
DROP INDEX `idx_site_status`;

✅ 四、外键(FOREIGN KEY)

1)新增外键约束

sql 复制代码
ALTER TABLE `coupon`
ADD CONSTRAINT `fk_coupon_campaign`
    FOREIGN KEY (`campaign_id`)
    REFERENCES `hot_campaign` (`id`)
    ON DELETE CASCADE
    ON UPDATE CASCADE;

2)删除外键

sql 复制代码
ALTER TABLE `coupon`
DROP FOREIGN KEY `fk_coupon_campaign`;

✅ 五、表结构变更

1)重命名表

sql 复制代码
RENAME TABLE `hot_campaign` TO `hot_campaign_v2`;

2)设置表的字符集

sql 复制代码
ALTER TABLE `hot_campaign`
CONVERT TO CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci;

✅ 六、删除表(DROP)

sql 复制代码
DROP TABLE IF EXISTS `hot_campaign`;
相关推荐
weelinking8 小时前
【产品】00_产品经理用Claude实现产品系列介绍
数据库·人工智能·sql·数据挖掘·github·产品经理
2301_803934619 小时前
Go语言如何做网络爬虫_Go语言爬虫开发教程【指南】
jvm·数据库·python
秋910 小时前
windows中安装redis
数据库·redis·缓存
Cosolar10 小时前
万字详解:RAG 向量索引算法与向量数据库架构及实战
数据库·人工智能·算法·数据库架构·milvus
想唱rap10 小时前
IO多路转接之poll
服务器·开发语言·数据库·c++
小江的记录本10 小时前
【Java基础】泛型:泛型擦除、通配符、上下界限定(附《思维导图》+《面试高频考点清单》)
java·数据结构·后端·mysql·spring·面试·职场和发展
SeaTunnel10 小时前
AI 让 SeaTunnel 读源码和调试过时了吗?
大数据·数据库·人工智能·apache·seatunnel·数据同步
凯瑟琳.奥古斯特11 小时前
数据冗余与规范化的本质[数据库原理]
开发语言·数据库·职场和发展
_ku_ku_11 小时前
数据库系统原理 · SQL 数据定义、更新及数据库编程 · 自学总结
数据库·oracle
Mortalbreeze11 小时前
深度理解文件系统 ---- 从磁盘存储到内核存储
大数据·linux·数据库