Skip to main content
Mobile DevelopmentTencentBlueKing

database-design

设计 BK-CI 数据库表、DDL 脚本、索引、分表或数据归档策略时使用。当用户提到表结构、字段设计、索引优化、SQL 脚本命名、分片、归档迁移时优先使用。

Stars
2,499
Source
TencentBlueKing/bk-ci
Updated
2026-05-28
Slug
TencentBlueKing--bk-ci--database-design
View on GitHubRaw SKILL.md

// install — copy + paste into any project

mkdir -p .claude/skills && curl -fsSL https://raw.githubusercontent.com/TencentBlueKing/bk-ci/HEAD/ai/skills/database-design/SKILL.md -o .claude/skills/database-design.md

Drops the SKILL.md into .claude/skills/database-design.md. Works with Claude Code, Cursor, and any agent that loads SKILL.md files from .claude/skills/.

BK-CI 数据库设计

适用场景

  • 新增或调整表结构
  • 编写 DDL、DML 或增量更新脚本
  • 设计索引、唯一约束、查询路径
  • 评估是否需要分表、归档或冷热分层
  • 审查某个数据模型是否适合当前服务边界

不适用场景

  • 只是写一条临时查询 SQL 排查数据
  • 只是改业务代码,不涉及持久化模型和表结构
  • 需求本质是 API 设计、模块归属或权限模型,不是数据库设计

快速指导

  1. 先确认数据归属到哪个服务。BK-CI 采用微服务拆分,禁止因为方便查询而跨服务共用数据库。
  2. 先决定表的角色,再决定字段和索引:
    • 主实体表:存核心业务状态
    • 关系表:表达多对多或映射关系
    • 汇总表:承载聚合读模型
    • 历史表:承载高频追加或归档数据
  3. 先按查询路径设计索引,不要先堆字段。最常用查询条件、排序字段、唯一约束字段优先进入索引设计。
  4. DDL 变更必须走脚本管理,不要直接在数据库里手工改线上结构。
  5. 变更前先考虑兼容性:
    • 老字段是否仍被旧版本代码读取
    • 新字段是否需要默认值
    • 是否需要分阶段发布
  6. 大表问题优先判断是索引、归档、冷热分层还是分表,不要默认直接分片。
  7. 对 JSON、大文本、状态快照类字段,要明确为什么不能拆表,避免把主表做成“万能存储”。

高信号规则

  • 脚本命名和版本目录要保持统一,详细规则见 reference/1-script-management.md
  • 分表与路由策略的细节见 reference/2-sharding.md
  • 表结构设计要服务于服务边界和查询模式,而不是追求理论上的“最全字段”
  • 能用代码层聚合解决的问题,不优先通过跨服务数据库耦合解决

关键陷阱

  • 只看写入模型,不看读路径,最后索引完全不匹配真实查询
  • 先建“超大宽表”,后续再靠补丁式字段堆积解决一切问题
  • 为了省事直接复用别的服务数据库,导致服务边界失效
  • 把分表当成性能优化默认选项,忽略归档、汇总和冷热拆分
  • 只改 DDL 不评估回滚、兼容和灰度发布路径

延伸阅读

  • 脚本管理:reference/1-script-management.md
  • 分表策略:reference/2-sharding.md
  • 如果需求同时涉及模块归属,先看 00-bkci-global-architecture