0

0

SQL数据库建模怎么做_详细步骤拆解实现完整应用场景【指导】

冰川箭仙

冰川箭仙

发布时间:2025-12-22 14:08:02

|

689人浏览过

|

来源于php中文网

原创

SQL数据库建模应先理解业务、梳理实体关系,再定义属性与约束,接着规范化设计消除冗余,最后落地建表并添加索引和注释;建模是持续演进过程,需随业务变化动态优化。

sql数据库建模怎么做_详细步骤拆解实现完整应用场景【指导】

SQL数据库建模不是先写CREATE TABLE,而是从理解业务开始,一步步把现实世界的关系翻译成结构清晰、可扩展、易维护的数据结构。核心是“先想清楚,再建表”,跳过分析直接建模,后期必然返工。

一、搞懂业务需求,画出核心实体和关系

这是建模的起点,也是最容易被跳过的一步。找业务方聊清楚:系统要管什么?谁在用?关键动作有哪些?比如做一个图书借阅系统,你会识别出“读者”“图书”“借阅记录”“管理员”等核心对象。

建议用白板或工具(如draw.io、Excalidraw)画出实体图(不带字段,只写名词),再用连线标注关系类型:

  • 读者 —— 借阅 —— 图书(一对多:一个读者可借多本书)
  • 图书 —— 归属 —— 分类(多对一:一本书只属于一个分类,一个分类下有多本书)
  • 借阅记录 —— 关联 —— 读者+图书(依赖型实体,需同时引用两者)

二、为每个实体定义属性,识别主键和约束

给每个实体补充具体字段,重点判断哪些是自然主键(如身份证号)、哪些适合用自增ID(如借阅记录ID),并标记必填、唯一、取值范围等约束。

例如“读者”实体可能包含:

  • reader_id(主键,BIGINT自增)
  • card_no(唯一,CHAR(18),需校验身份证格式)
  • name(NOT NULL,VARCHAR(50))
  • phone(可加CHECK正则匹配手机号)
  • created_at(默认CURRENT_TIMESTAMP)

注意避免冗余字段——比如“读者”里不存“当前借了几本书”,这个应通过关联查询实时统计。

Lessie AI
Lessie AI

一款定位为「People Search AI Agent」的AI搜索智能体

下载

三、规范化设计:拆分表结构,消除数据异常

按范式逐步检查,重点到第三范式(3NF)即可。常见问题包括:

  • 字段重复出现(如多张表都有address)→ 提炼出“地址”表,用外键关联
  • 一个字段存多个值(如“兴趣爱好”用逗号隔开)→ 拆成“读者_爱好”中间表
  • 非主键字段依赖非主键(如订单表里存了客户所在城市,而城市实际由客户ID决定)→ 把城市移到客户表

不必强求BCNF或第四范式,过度拆分反而增加JOIN成本,尤其在读多写少场景中要权衡。

四、落地建表:写SQL + 补充索引与注释

建表语句不是终点,而是交付物的一部分。每张表建议包含:

  • ENGINE=InnoDB(保障事务与外键)
  • 显式定义字符集(如DEFAULT CHARSET=utf8mb4)
  • COMMENT说明表用途(如COMMENT '读者基本信息,含实名认证状态')
  • 为高频查询字段加索引(如借阅表上(reader_id, status)联合索引支持“某读者所有待还书”查询)
  • 外键约束写明ON DELETE行为(如图书删除时,借阅记录设为NULL或拒绝删除,视业务而定)

示例片段:

CREATE TABLE `borrow_record` (
  `id` BIGINT PRIMARY KEY AUTO_INCREMENT,
  `reader_id` BIGINT NOT NULL,
  `book_id` BIGINT NOT NULL,
  `borrowed_at` DATETIME DEFAULT CURRENT_TIMESTAMP,
  `returned_at` DATETIME NULL,
  `status` TINYINT DEFAULT 1 COMMENT '1-已借出,2-已归还,3-已逾期',
  INDEX idx_reader_status (`reader_id`, `status`),
  FOREIGN KEY (`reader_id`) REFERENCES `reader`(`id`) ON DELETE CASCADE,
  FOREIGN KEY (`book_id`) REFERENCES `book`(`id`) ON DELETE RESTRICT
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COMMENT='读者借阅流水,含状态与时间戳';

基本上就这些。建模不是一次性任务,随着业务演进要持续回顾——新增字段是否破坏范式?查询变慢是不是缺索引?表之间耦合是否太紧?保持模型“活”着,比一开始追求完美更重要。

相关专题

更多
数据分析工具有哪些
数据分析工具有哪些

数据分析工具有Excel、SQL、Python、R、Tableau、Power BI、SAS、SPSS和MATLAB等。详细介绍:1、Excel,具有强大的计算和数据处理功能;2、SQL,可以进行数据查询、过滤、排序、聚合等操作;3、Python,拥有丰富的数据分析库;4、R,拥有丰富的统计分析库和图形库;5、Tableau,提供了直观易用的用户界面等等。

678

2023.10.12

SQL中distinct的用法
SQL中distinct的用法

SQL中distinct的语法是“SELECT DISTINCT column1, column2,...,FROM table_name;”。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

320

2023.10.27

SQL中months_between使用方法
SQL中months_between使用方法

在SQL中,MONTHS_BETWEEN 是一个常见的函数,用于计算两个日期之间的月份差。想了解更多SQL的相关内容,可以阅读本专题下面的文章。

346

2024.02.23

SQL出现5120错误解决方法
SQL出现5120错误解决方法

SQL Server错误5120是由于没有足够的权限来访问或操作指定的数据库或文件引起的。想了解更多sql错误的相关内容,可以阅读本专题下面的文章。

1095

2024.03.06

sql procedure语法错误解决方法
sql procedure语法错误解决方法

sql procedure语法错误解决办法:1、仔细检查错误消息;2、检查语法规则;3、检查括号和引号;4、检查变量和参数;5、检查关键字和函数;6、逐步调试;7、参考文档和示例。想了解更多语法错误的相关内容,可以阅读本专题下面的文章。

357

2024.03.06

oracle数据库运行sql方法
oracle数据库运行sql方法

运行sql步骤包括:打开sql plus工具并连接到数据库。在提示符下输入sql语句。按enter键运行该语句。查看结果,错误消息或退出sql plus。想了解更多oracle数据库的相关内容,可以阅读本专题下面的文章。

675

2024.04.07

sql中where的含义
sql中where的含义

sql中where子句用于从表中过滤数据,它基于指定条件选择特定的行。想了解更多where的相关内容,可以阅读本专题下面的文章。

573

2024.04.29

sql中删除表的语句是什么
sql中删除表的语句是什么

sql中用于删除表的语句是drop table。语法为drop table table_name;该语句将永久删除指定表的表和数据。想了解更多sql的相关内容,可以阅读本专题下面的文章。

415

2024.04.29

Golang gRPC 服务开发与Protobuf实战
Golang gRPC 服务开发与Protobuf实战

本专题系统讲解 Golang 在 gRPC 服务开发中的完整实践,涵盖 Protobuf 定义与代码生成、gRPC 服务端与客户端实现、流式 RPC(Unary/Server/Client/Bidirectional)、错误处理、拦截器、中间件以及与 HTTP/REST 的对接方案。通过实际案例,帮助学习者掌握 使用 Go 构建高性能、强类型、可扩展的 RPC 服务体系,适用于微服务与内部系统通信场景。

8

2026.01.15

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
React 教程
React 教程

共58课时 | 3.7万人学习

Pandas 教程
Pandas 教程

共15课时 | 0.9万人学习

ASP 教程
ASP 教程

共34课时 | 3.6万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号