谁再问你数据库三范式,这篇文章甩给他!!!

前几天有粉丝私信说面试被问到了数据库三范式(面试问这种的不去也好),今天我们就来聊聊。在数据库设计的过程中,为了确保数据的准确性和完整性,我们通常遵循一定的规则和标准,其中最为人所熟知的便是“数据库三范式”。

数据库范式(Database Normalization)是数据库设计的一系列最佳实践,主要目标就是减少数据冗余、提升数据一致性,并使得数据库结构更加清晰、易于维护。数据库范式有多个级别,其中最基本且最重要的是前三个范式,即第一范式(1NF)、第二范式(2NF)和第三范式(3NF)。

第一范式(1NF)

第一范式是最基本的范式,它要求数据库表的每一列都是不可分割的原子项。换句话说,表中不能有重复的列,也不能有复合数据类型(如数组、记录等)。

示例:

假设我们有一个存储学生信息的表,其中包含“姓名”、“学号”和“联系方式”等字段。如果我们将“联系方式”这一列拆分为“电话”和“邮箱”两个字段,那么这个表就满足了第一范式。

第二范式(2NF)

第二范式建立在第一范式的基础上,它要求数据库表中的非主键列必须完全依赖于整个主键,而不能只依赖于主键的一部分。

示例:

考虑一个订单表,其中包含“订单号”、“产品ID”和“产品数量”等字段。其中,“订单号”和“产品ID”共同组成复合主键。如果“产品数量”只与“产品ID”有关,而与“订单号”无关,那么这个表就不满足第二范式。为了使其满足第二范式,我们可以将“产品数量”字段移到一个新的表中,该表以“产品ID”为主键,并通过外键与订单表关联。

第三范式(3NF)

第三范式是对第二范式的进一步约束,它要求一个数据库表中不包含已在其他表中已包含的非主键信息,并且非主键列之间不存在传递依赖关系。

示例:

继续以上面的订单表为例,假设我们还有一个字段“产品价格”,这个字段与“产品ID”有关,而与“订单号”无关。如果我们把“产品价格”放在订单表中,那么订单表就包含了关于产品的冗余信息,因为产品价格应该只与产品本身有关,而与订单无关。为了满足第三范式,我们应该将“产品价格”字段移到一个专门的产品表中,并通过外键与订单表关联。

总结

数据库三范式是数据库设计中的重要原则,它们有助于我们构建结构清晰、数据冗余少的数据库系统。然而,在实际应用中,我们也需要根据具体需求和性能考虑进行权衡,有时候为了查询性能或业务逻辑的需要,可能会适当地放宽范式的约束。

欢迎关注我的公众号“程序员洋哥”,原创技术文章第一时间推送。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/772598.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

linux文本三剑客 --- grep、sed、awk

1、grep grep&#xff1a;使用正则表达式搜索文本&#xff0c;将匹配的行打印出来&#xff08;匹配到的标红&#xff09; 命令格式&#xff1a;grep [option] pattern file <1> 命令参数 -A<显示行数>&#xff1a;除了显示符合范本样式的那一列之外&#xff0c;并…

类,并快乐着---python中的类

类&#xff0c;并快乐着---python中的类 争取让你获取类的快乐&#xff01;\ 在Python中&#xff0c;类是一种用来创建对象的蓝图或模板。类定义了对象的属性和方法&#xff0c;可以通过类来创建多个对象实例。 所谓类&#xff0c;并快乐着。让你欲罢不能。 下面是Python中类…

MongoDB 的索引有哪些 nestjs mongoose示例

MongoDB 的索引有哪些 nestjs mongoose示例 复合索引&#xff08;Compound Index&#xff09;&#xff1a; 索引多个字段&#xff0c;允许对这些字段的组合进行高效查询。例如&#xff0c;您可以创建一个索引 { name: 1, age: 1 }&#xff0c;以便可以快速查询按姓名和年龄排序…

解不开的心结就让他系成蝴蝶结吧!

解不开的心结&#xff0c;就让它变成蝴蝶结吧 生活中&#xff0c;我们都会遇到一些难以解开的心结。它们像一块块绊脚石&#xff0c;让我们在前进的路上跌跌撞撞。面对这些心结&#xff0c;我们往往陷入了深深的思考和无尽的纠结。但是&#xff0c;有没有一种更优雅、更积极的…

【C语言】鸡兔同笼,鸡和兔共 100 只,共 284 只脚,求鸡和兔的个数。

鸡兔同笼&#xff0c;鸡和兔共 100 只&#xff0c;共 284 只脚&#xff0c;求鸡和兔的个数。 int main() {for (int i 0; ; i){if (2 * i 4 * (100 - i) 284){printf("鸡的数量&#xff1a;%d,兔子的数量&#xff1a;%d", i, 100 - i);break;} } }这里直接算出题…

开源博客项目Blog .NET Core源码学习(11:App.Core项目结构分析)

开源博客项目Blog的App.Core项目主要定义数据库表对应的数据类&#xff0c;同时定义配置文件读取、日志记录、辅助缓存等辅助类。App.Core项目安装的Nuget包不多&#xff0c;仅包括SqlSugarCore和Microsoft.Extensions.DependencyInjectio两类。   App.Core项目的顶层文件夹如…

Git本地项目开发流程记录

背景 基于Git Bash本地创建项目&#xff0c;了解Git项目开发的基本流程&#xff0c;便于管理和记录算法开发流程&#xff0c;规范代码结构。相关概念 Git分区&#xff1a;工作区&#xff0c;缓存区&#xff0c;版本区。工作区即代码开发的本地文件&#xff0c;缓存区为使用Git …

TouchGFX之Drawable

TouchGFX框架中的所有控件均为Drawable类的子类。 该类别包含控制大小和位置的一般方法。 #ifndef TOUCHGFX_DRAWABLE_HPP #define TOUCHGFX_DRAWABLE_HPP #include <touchgfx/Bitmap.hpp> #include <touchgfx/events/ClickEvent.hpp> #include <touchgfx/event…

AI智能客服:引领企业客户服务新篇章

AI智能客服&#xff1a;高效处理客户咨询的新选择 AI智能客服能够自动识别客户的语音或文字信息&#xff0c;通过自然语言处理技术理解其意图和需求&#xff0c;并快速给出准确的回答或建议。无论是常见的产品查询、订单状态确认&#xff0c;还是复杂的投诉建议&#xff0c;AI…

WEB测试之兼容性测试

1. 软件兼容性测试 兼容性测试是指待测试项目在特定的硬件平台上&#xff0c;不同的应用软件之间&#xff0c;不同的操作系统平台上&#xff0c;在不同的网络等环境中能正常的运行的测试。 兼容性测试的目的&#xff1a;待测试项目在不同的操作系统平台上正常运行&#xff0c…

[蓝桥杯 2023 省 A] 颜色平衡树:从零开始理解树上莫队 一颗颜色平衡树引发的惨案

十四是一名生物工程的学生&#xff0c;他已经7年没碰过信息学竞赛了&#xff0c;有一天他走在蓝桥上看见了一颗漂亮的颜色平衡树&#xff1a; ​​​​​​​[蓝桥杯 2023 省 A] 颜色平衡树 - 洛谷 十四想用暴力解决问题&#xff0c;他想枚举每个节点&#xff0c;每个节点代表…

Word通配符替换章节序号

这里写自定义目录标题 通配符替换章节序号切换域通配符替换内容插入编号切换域代码 通配符替换章节序号 碎片化学习word通配符知识 切换域 切换域&#xff1a;Alt F9 域都变成静态文字&#xff1a;Ctrl/Command Shift F9 通配符 内容通配符单个数字[0-9]多个数字&#…

office办公技能|word中的常见使用问题解决方案2.0

一、设置多级列表将表注从0开始&#xff0c;设置为从1开始 问题描述&#xff1a;word中插入题注&#xff0c;出来的是表0-1&#xff0c;不是1-1&#xff0c;怎么办&#xff1f; 写论文时&#xff0c;虽然我设置了“第一章”为一级标题&#xff0c;但是这三个字并不是自动插入的…

工作中的障念 - AI运算超时

hi,为什么我在工作的时候会遭遇一种无法描述的障念&#xff0c;问题并不复杂&#xff0c;但是似乎有一堵无形的墙当着自己不能前进。这是一种普遍现象吗&#xff1f; ## 来自WeTab AI的消息: 嗨&#xff0c;听起来你在工作时遇到的障碍可能是一种称为“工作障碍”的现象。这种…

k8s 的资源清单

K8S 的资源清单 参数名类型字段说明apiVersionStringK8S APl 的版本&#xff0c;可以用 kubectl api versions 命令查询kindStringyam 文件定义的资源类型和角色metadataObject元数据对象&#xff0c;下面是它的属性metadata.nameString元数据对象的名字&#xff0c;比如 pod …

构建一个springboot项目

构建一个springboot项目&#xff0c;需要下载哪些软件与工具&#xff1f; 要构建一个Spring Boot项目&#xff0c;通常需要以下软件和工具&#xff1a; Java Development Kit&#xff08;JDK&#xff09;&#xff1a; Spring Boot是基于Java开发的&#xff0c;因此需要安装JD…

基于STM32的智能药盒设计

基于STM32的智能药盒设计 摘要 随着现代医疗技术的进步和智能家居的普及&#xff0c;智能药盒作为家庭医疗健康管理的重要组成部分&#xff0c;受到了越来越多的关注。本文设计并实现了一种基于STM32微控制器的智能药盒系统&#xff0c;该系统能够实时监测药品的存储状态&…

【C语言】【Leetcode】70. 爬楼梯

文章目录 题目思路&#xff1a;简单递归 > 动态规划 题目 链接: link 思路&#xff1a;简单递归 > 动态规划 这题类似于斐波那契数列的算法&#xff0c;结果其实就是到达前一步和到达前两步的方法之和&#xff0c;一直递归到n1和n2时就行了&#xff0c;但是这种算法有个…

解决vllm推理框架内在开启多显卡时报错问题

前言 vLLM在开启多显卡并行模式下&#xff0c;-tp 2 或者 --tensor-parallel-size 2&#xff0c;运行报错提示如下&#xff1a; The above exception was the direct cause of the following exception:Traceback (most recent call last): File "/usr/lib/python3.8/ru…

多线程中线程间如何通信

除了使用synchronized来对代码块和方法进行同步外&#xff0c;jdk1.5之后还有一种Lock同步锁的方式进行同步&#xff1a;使用lock.lock()来进行加锁&#xff0c;使用lock.unlock()方法来释放锁&#xff0c;既然可以使用lock来代替synchronized&#xff0c;那么如何进行处理sync…