生成数据库迁移文件。当用户需要创建表、修改表结构、添加索引等数据库变更时使用此 skill。
生成符合项目规范的 golang-migrate 迁移文件。
migrations/ 目录,确定下一个可用序号make migrate-up 执行迁移migrations/{yyyymmddhhiiss}{3位序号}_{snake_case描述}.up.sql
migrations/{yyyymmddhhiiss}{3位序号}_{snake_case描述}.down.sql
格式说明:
yyyymmddhhiiss - 年月日时分秒(14位)3位序号 - 同一秒内的序号(001-999)示例:20251229035300001_create_users_table.up.sql
CREATE TABLE IF NOT EXISTS `table_name` (
`id` BIGINT UNSIGNED NOT NULL AUTO_INCREMENT COMMENT '主键ID',
`name` VARCHAR(100) NOT NULL COMMENT '名称',
`status` TINYINT UNSIGNED NOT NULL DEFAULT 1 COMMENT '状态: 0-禁用, 1-正常',
`created_at` TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
`updated_at` TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间',
PRIMARY KEY (`id`),
KEY `idx_status` (`status`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci COMMENT='表注释';
DROP TABLE IF EXISTS `table_name`;
ALTER TABLE `table_name` ADD COLUMN `field_name` VARCHAR(100) NOT NULL DEFAULT '' COMMENT '字段说明' AFTER `existing_field`;
ALTER TABLE `table_name` DROP COLUMN `field_name`;
ALTER TABLE `table_name` ADD INDEX `idx_field` (`field_name`);
-- 或唯一索引
ALTER TABLE `table_name` ADD UNIQUE KEY `uk_field` (`field_name`);
ALTER TABLE `table_name` DROP INDEX `idx_field`;
| 用途 | 类型 | 示例 |
|---|---|---|
| 主键 | BIGINT UNSIGNED AUTO_INCREMENT | id |
| 外键 | BIGINT UNSIGNED | user_id |
| 短字符串 | VARCHAR(n) | name VARCHAR(100) |
| 长文本 | TEXT | content |
| 枚举状态 | TINYINT UNSIGNED | status TINYINT UNSIGNED DEFAULT 1 |
| 金额 | DECIMAL(10,2) | price |
| 时间戳 | TIMESTAMP | created_at, updated_at |
| 日期 | DATE | birth_date |
| 布尔 | TINYINT(1) | is_active TINYINT(1) DEFAULT 1 |
| JSON | JSON | metadata |
| 类型 | 前缀 | 示例 |
|---|---|---|
| 普通索引 | idx_ | idx_user_id |
| 唯一索引 | uk_ | uk_email |
| 联合索引 | idx_ | idx_user_status |
IF NOT EXISTS / IF EXISTS# 执行所有迁移
make migrate-up
# 回滚上一个
make migrate-down
# 查看当前版本
make migrate-version