当前位置: 首页 > news >正文

数据库三范式设计---小白初学+案例引入

背景:

模拟一个简单版计算器,两位操作数运算,运算符号包括+-*/,目前是把这些数据存储到了MySQL数据库中,库为cal,表名为success,如图:

CREATE TABLE success (id INT AUTO_INCREMENT PRIMARY KEY,nums VARCHAR(255) NOT NULL COMMENT '用户输入的运算表达式,如1+1',result DOUBLE NOT NULL COMMENT '运算结果',spend_time BIGINT NOT NULL COMMENT '计算耗时(毫秒)',created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP
);

输入关键字history可以进行查询操作:

 

问题分析:

  1. 这种“22+78”的nums存储是非结构化的 ,存储的是表达式字符串
  2. 还有耗时这一块,应该直接存储7即可,不要存一串描述文字
  3. 不符合三范式(3NF),表达式和结果之间存在函数依赖(result = function(nums))
  4. 扩展性差

改进方案:

使用数据库三范式设计,步骤如下:

一、首先先理解三大范式:

  1. 第一范式(1NF):每个字段都是不可分割的原子值

  2. 第二范式(2NF):满足1NF,且非主键字段完全依赖主键(针对联合主键)

  3. 第三范式(3NF):满足2NF,且消除传递依赖(非主键字段间不能有依赖)

二、从需求出发设计:

分析需求:
  • 需要记录的有:id,操作数1,运算符,操作数2,结果,耗时,创建时间

  • 主实体

    • 计算记录(cal):id、耗时、结果、创建时间

  • 子实体

    • 操作数(operand):值、位置(即第几个数)

    • 运算符(operator):符号类型(比如+-*/)

三、表设计:

场景模拟:

现在要保存「3 + 5」的运算记录:

  1. 先创建「计算记录」主表条目(生成cal_id=1)

  2. 接着要在operands表插入两条记录:

    • (cal_id=1, position=1, value=3)

    • (cal_id=1, position=2, value=5)

  3. 最后在operators表插入:

    • (cal_id=1, operator='+')

总结:三表设计方案,分别是cal、operands、operators三张表

四、三表设计(完全范式化)代码:

-- 运算记录主表
CREATE TABLE cal (id INT AUTO_INCREMENT PRIMARY KEY,spend_time BIGINT NOT NULL COMMENT '计算耗时(毫秒)',result DOUBLE NOT NULL COMMENT '计算结果',created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP
);-- 运算数表
CREATE TABLE operands (id INT AUTO_INCREMENT PRIMARY KEY,cal_id INT NOT NULL COMMENT '关联计算记录',position INT NOT NULL COMMENT '操作数位置(1,2,...)',param DOUBLE NOT NULL COMMENT '操作数值',FOREIGN KEY (cal_id) REFERENCES cal(id)
);-- 运算符表
CREATE TABLE operators (id INT AUTO_INCREMENT PRIMARY KEY,cal_id INT NOT NULL COMMENT '关联计算记录',operator CHAR(2) NOT NULL COMMENT '运算符,如+,-,*,/',FOREIGN KEY (cal_id) REFERENCES cal(id)
);

界面化展示三张表结构:

 

 

为什么满足三范式?
  1. 满足1NF:所有字段都是原子值

  2. 满足2NF

    • 单列主键不存在部分依赖问题

    • 外键关系完整

  3. 满足3NF

    • 消除了传递依赖(如原设计result依赖nums)

    • 各表非主键字段只依赖主键

但是这种三表设计复杂度比较高(需要多表join查询),但同时灵活性也很高(支持任意数量操作数)

这里我们虽然只是一个简单计算器没必要这么麻烦,但是主要是为了学习三范式数据库表设计,所以还是用三表设计!配合下面的时序图来理解三张表的关系!

修改之后: 

注意细节:

cal表的created_at:


下一篇再讲讲三表查询SQL怎么写!^_^

相关文章:

  • 数据分析实战2(Tableau)
  • SpringCloud-基于SpringAMQP实现消息队列
  • 矩阵分解相关知识点总结(二)
  • 使用 C/C++ 和 OpenCV 添加图片水印
  • 接IT方案编写(PPT/WORD)、业务架构设计、投标任务
  • DAY 21 常见的降维算法
  • OpenAI技术路线急转:从TypeScript到Rust的Codex CLI重构内幕
  • Spring WebFlux 整合AI大模型实现流式输出
  • Python-内置函数
  • MCP协议在LLM系统中的架构与实现原理研究
  • Cursor 集成 Figma MCP 实现阅读理解原型图生成方案
  • SQL Server相关的sql语句
  • PPT转图片拼贴工具 v2.0
  • 《EDA学习地图:从入门到进阶的通关秘籍》
  • [10-2]MPU6050简介 江协科技学习笔记(22个知识点)
  • Git的由来与应用详解:从Linux内核到现代开发的革命性工具
  • C++学习-入门到精通【14】标准库算法
  • AI应用工程师面试
  • Spring Boot 常用注解面试题深度解析
  • 从二叉树到 STL:揭开 set 容器的本质与用法
  • 建网站做哪方面/seo快速排名工具
  • 返利网站建设哪个公司好/网络app推广是什么工作
  • 网站建设实训教程/谷歌三件套下载
  • 武汉公司做网站/竞价代运营
  • 网站301的作用/营销策划书模板范文
  • 视频网站VIP卡怎么做赠品/seo快速排名系统