Files
tyapi-server/scripts/migrations/001_create_article_tables.sql
2025-09-01 18:29:59 +08:00

97 lines
4.6 KiB
SQL

-- 文章系统数据库迁移脚本
-- 创建时间: 2024-01-01
-- 描述: 创建文章相关的数据库表结构
-- 文章分类表
CREATE TABLE IF NOT EXISTS article_categories (
id VARCHAR(36) PRIMARY KEY COMMENT '分类唯一标识',
name VARCHAR(100) NOT NULL COMMENT '分类名称',
description TEXT COMMENT '分类描述',
sort_order INT DEFAULT 0 COMMENT '排序',
active BOOLEAN DEFAULT TRUE COMMENT '是否启用',
created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
updated_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间',
deleted_at TIMESTAMP NULL COMMENT '软删除时间',
INDEX idx_article_categories_active (active),
INDEX idx_article_categories_sort_order (sort_order),
INDEX idx_article_categories_deleted_at (deleted_at)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci COMMENT='文章分类表';
-- 文章标签表
CREATE TABLE IF NOT EXISTS article_tags (
id VARCHAR(36) PRIMARY KEY COMMENT '标签唯一标识',
name VARCHAR(50) NOT NULL COMMENT '标签名称',
color VARCHAR(20) DEFAULT '#1890ff' COMMENT '标签颜色',
created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
updated_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间',
deleted_at TIMESTAMP NULL COMMENT '软删除时间',
UNIQUE KEY uk_article_tags_name (name),
INDEX idx_article_tags_deleted_at (deleted_at)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci COMMENT='文章标签表';
-- 文章表
CREATE TABLE IF NOT EXISTS articles (
id VARCHAR(36) PRIMARY KEY COMMENT '文章唯一标识',
title VARCHAR(200) NOT NULL COMMENT '文章标题',
content TEXT NOT NULL COMMENT '文章内容',
summary VARCHAR(500) COMMENT '文章摘要',
cover_image VARCHAR(500) COMMENT '封面图片',
category_id VARCHAR(36) COMMENT '分类ID',
status ENUM('draft', 'published', 'archived') DEFAULT 'draft' COMMENT '文章状态',
is_featured BOOLEAN DEFAULT FALSE COMMENT '是否推荐',
published_at TIMESTAMP NULL COMMENT '发布时间',
view_count INT DEFAULT 0 COMMENT '阅读量',
created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
updated_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间',
deleted_at TIMESTAMP NULL COMMENT '软删除时间',
INDEX idx_articles_category_id (category_id),
INDEX idx_articles_status (status),
INDEX idx_articles_is_featured (is_featured),
INDEX idx_articles_published_at (published_at),
INDEX idx_articles_created_at (created_at),
INDEX idx_articles_deleted_at (deleted_at),
FOREIGN KEY (category_id) REFERENCES article_categories(id) ON DELETE SET NULL
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci COMMENT='文章表';
-- 文章标签关联表
CREATE TABLE IF NOT EXISTS article_tag_relations (
id VARCHAR(36) PRIMARY KEY COMMENT '关联记录唯一标识',
article_id VARCHAR(36) NOT NULL COMMENT '文章ID',
tag_id VARCHAR(36) NOT NULL COMMENT '标签ID',
created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
UNIQUE KEY uk_article_tag_relation (article_id, tag_id),
INDEX idx_article_tag_relations_article_id (article_id),
INDEX idx_article_tag_relations_tag_id (tag_id),
FOREIGN KEY (article_id) REFERENCES articles(id) ON DELETE CASCADE,
FOREIGN KEY (tag_id) REFERENCES article_tags(id) ON DELETE CASCADE
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci COMMENT='文章标签关联表';
-- 插入默认分类数据
INSERT INTO article_categories (id, name, description, sort_order, active) VALUES
('cat-001', '技术分享', '技术相关的文章分享', 1, true),
('cat-002', '产品介绍', '产品功能介绍和使用指南', 2, true),
('cat-003', '公司动态', '公司最新动态和新闻', 3, true),
('cat-004', '行业资讯', '行业相关的最新资讯', 4, true),
('cat-005', '用户指南', '用户使用指南和帮助文档', 5, true)
ON DUPLICATE KEY UPDATE
name = VALUES(name),
description = VALUES(description),
sort_order = VALUES(sort_order),
active = VALUES(active);
-- 插入默认标签数据
INSERT INTO article_tags (id, name, color) VALUES
('tag-001', '技术', '#1890ff'),
('tag-002', '产品', '#52c41a'),
('tag-003', '新闻', '#faad14'),
('tag-004', '教程', '#722ed1'),
('tag-005', '更新', '#13c2c2'),
('tag-006', 'API', '#eb2f96'),
('tag-007', '文档', '#fa8c16'),
('tag-008', '公告', '#f5222d')
ON DUPLICATE KEY UPDATE
name = VALUES(name),
color = VALUES(color);