什么是数据库范式,是否应该严格遵守范式,什么情况下应该不遵守范式?

这里是修真院后端小课堂,每篇分享文从

【背景介绍】【知识剖析】【常见问题】【解决方案】【编码实战】【扩展思考】【更多讨论】【参考文献】

八个方面深度解析后端知识/技能,本篇分享的是:

什么是数据库范式,是否应该严格遵守范式,什么情况下应该不遵守范式?

【修真院java 小课堂】 什么是数据库范式,是否应该严格遵守范式,什么情况下应该不遵守范式?

大家好,我是IT修真院郑州分院第12期的学员张泉良,一枚正直纯洁善良的JAVA程序员,今天给大家分享一下,

修真院官网JAVA任务三,深度思考中的知识点——什么是数据库范式,是否应该严格遵守范式,什么情况下应该不遵守范式?

1. 背景介绍:

(1) 关系型数据库

     关系型数据库是依据关系模型来创建的数据库

     关系模型就是指二维表格模型,因而一个关系型数据库就是由二维表及其之间的联系组成的一个数据组织

     关系模型包括数据结构(数据存储的问题,二维表)、操作指令集合(SQL语句)、完整性约束

    (表内数据约束、表与表之间的约束)

(2)常见的关系数据库:

  Oracle、DB2、PostgreSQL、Microsoft SQL Server、Microsoft Access、MySQL

                安全(因为存储在磁盘)

                容易理解(建立在关系模型上)

                但不节省空间)

                中间产生的规则就是范式以及约束   

2. 知识剖析:

(1) 什么是范式

    当设计关系型数据库时,需要遵从不同的规范要求,设计出合理的关系型数据库,

    这些不同的规范要求被称为不同的范式(Normal Form),

    越高的范式数据库冗余越小。应用数据库范式可以带来许多好处,

    但是最主要的目的是为了消除重复数据,减少数据冗余,让数据库内的数据更好的组织,

    让磁盘空间得到更有效的利用。

    范式的缺点:范式使查询变的相当复杂,在查询时需要更多的连接,

    一些复合索引的列由于范式化的需要被分割到不同的表中,导致索引策略不佳。  

(2)什么是第一、二、三、BC范式?

    所谓“第几范式”,是表示关系的某一种级别,所以经常称某一关系R为第几范式。

    目前关系型数据库有六种范式:第一范式(1NF)、第二范式(2NF)、第三范式(3NF)、

    巴斯-科德范式(BCNF)、第四范式(4NF)和第五范式(5NF,又称完美范式)。

    满足最低要求的范式是第一范式(1NF)。在第一范式的基础上进一步满足更多规范要求的称为第二范式(2NF),

    其余范式以次类推。满足高等级的范式的先决条件是必须先满足低等级范式。

    

    4NF:要求把同一表内的多对多关系删除

    5NF:从最终结构重新建立原始结构

(3) 范式中会用到的一些常用概念

    a、实体(Entity):就是实际应用中要用数据描述的事物,它是现实世界中客观存在并可以被区别的事物

    b、数据项(Data Item):即字段(Fields)也可称为域、属性、列。数据项是数据的不可分割的最小单位。

    c、数据元素(Data Element):数据元素是数据的基本单位。数据元素也称元素、行、元祖、记录(Record)。

            一个数据元素可以由若干个数据项组成。表中的一行就是一个元组。 

    d、码:也称为键(Key)它是数据库系统中的基本概念。所谓码就是能唯一标识实体的属性,它是整个实体集的性质,而不是单个实体的性质。它包括超码、候选码和主码。

    e、超码:超码是一个或多个属性的集合,这些属性的组合可以在一个实体集中唯一地标识一个实体。

       如果K是一个超码,那么K的任意超集也是超码,也就是说如果K是超码,那么所有包含K的集合也是超码。

    f、候选码:在一个超码中,可能包含了无关紧要的属性,如果对于一些超码,他们的任意真子集都不能成为超码,那么这样的最小超码称为候选码。

    g、主码:从候选码中挑一个最少键的组合,它就叫主码(主键,Primary Key)。

        每个主码应该具有下列特征:1.唯一的。2.最小的(尽量选择最少键的组合)。3.非空。4.不可更新的

    h、全码:如果一个码包含了所有的属性,这个码就是全码(All-key)。

        主属性:一个属性只要在任何一个候选码中出现过,这个属性就是主属性(Prime Attribute)。

        非主属性:与主属性相反,没有在任何候选码中出现过,这个属性就是非主属性(Nonprime Attribute)或非码属性

    g、外码:关系模式R中的一个属性或属性组X并非R的码,但X是另一个关系模式的码,则称X是R的外码,也称外键(Foreign Key)。

    k、依赖表(Dependent Table)也称为弱实体(Weak Entity)是需要用父表标识的子表。

    m、关联表(Associative Table):是多对多关系中两个父表的子表。

    n、函数依赖:函数依赖是指关系中一个或一组属性的值可以决定其它属性的值。

        函数依赖:X → Y。函数依赖不是指关系模式R的某个或某些关系满足的约束条件,

         而是指R的一切关系均要满足的约束条件。

    o、完全函数依赖:在一个关系中,若某个非主属性数据项依赖于全部关键字称之为完全函数依赖。

    p、传递函数依赖:指的是如果存在“A → B → C”的决定关系,则C传递函数依赖于A。

3. 常见问题:

(1)、如何更好的区分三大范式

    第 一范式和第二范式在于有没有分出两张表,

    第二范式是说一张表中包含了多种不同的实体属性,那么要必须分成多张表, 

    第三范式是要求已经分成了多张表,那么一张表中只能有另一张表中的id(主键),

    而不能有其他的任何信息(其他的信息一律用主键在另一表查询)。

(2)、外键的注意点

    只有INNODB的数据库引擎支持外键

    外键必须与参照列的数据类型必须相同(数值型要求长度和无符号都相同,字符串要求类型相同,长度可以不同)

        CONSTRAINT 外键名 FOREIGN KEY (外键字段)REFERENCES 参照表 (参照字段)

    CASCADE删除或更新参照表的参照字段时,外键表的记录同步删除更新              

    SET NULL 删除或更新参照表的参照字段时,外键表的外键设为NULL

(3)、何谓反范式?什么情况需要做反范式设计?

    反范式,denormalization,字面上就是做范式的反义词,事实上也是。

    遵循范式总体上来说是为了保证数据的integrity和减少冗余,

    但是,从直觉上我们就可以知道,一个完全按照范式设计的冗余极低的数据库,

    很可能在性能上会输给冗余相对多一些的数据库(比如说3NF的数据库,表多,关系复杂,数据库的IO次数很多,性能会收到影响)。

    最典型的就是在一些数据表中不仅存作为外键的user_id,同样存user_name,这样虽然违反数据库范式增加了user_name字段,

    但是却提高了效率,减少了获取user_id后再去user表中获取user name的操作

4. 编码实战:

5. 拓展思考:

(1):数据库的约束有哪些

    primary KEY:设置主键约束

    UNIQUE:设置唯一性约束,不能有重复值

    DEFAULT 默认值约束,height DOUBLE(3,2)DEFAULT 1.2 height不输入是默认为1.2

    NOT NULL:设置非空约束,该字段不能为空;

    FOREIGN key :设置外键约束。

(2).做范式的目的:

    减少冗余,减少异常(delete,update,insert)

    让数据组织的更加和谐

    通过范式的不断升级,我们会发现应用的范式等级越高,则表越多。表多会带来很多问题:

    查询时要连接多个表,增加了查询的复杂度

    查询时需要连接多个表,降低了数据库查询性能

6. 参考文献:

    https://blog.csdn.net/sylvanasgq/article/details/79368159

   https://blog.csdn.net/apt1203jn/article/details/80314605

   https://yq.aliyun.com/ziliao/495680

7.  更多讨论:

   Q1: 什么是"级联",级联操作是什么意思?

   A1: 

级联是用来设计一对多关系的。例如一个表存放老师的信息:表A(姓名,性别,年龄),姓名为主键。

还有一张表存放老师所教的班级信息:表B(姓名,班级)。他们通过姓名来级联。级联的操作有级联更新,级联删除。

在启用一个级联更新选项后,就可在存在相匹配的外键值的前提下更改一个主键值。系统会相应地更新所有匹配的外键值。如果在表A中将姓名为张三的记录改为李四,那么表B中的姓名为张三的所有记录也会随着改为李四。级联删除与更新相类似。如果在表A中将姓名为张三的记录删除,那么表B中的姓名为张三的所有记录也将删除。

 Q2:  设置外键以后怎么新增数据?

 A2:  (1)先主表插入数据的时候,必须保证关联外键的外键表存在主表要插入的数据,

               比如:班级信息表中,教师姓名是 外键,当我们插入班级信息中,要想保证老师表中对应姓名村存在

        (2) 暂时关闭外键约束,可能导致数据不一致

              SET SQL_SAFE_UPDATES=0;SET FOREIGN_KEY_CHECKS=0;         

Q3: 不建立外键,不用表连接,如何查询两个关联表的数据?

 A3:    嗯,可以使用 where 语句,  比如      select s.name,c.name where s.id= c.id 

          

8.  鸣谢:

9.  结束语:

今天的分享就到这里啦,欢迎大家点赞、转发、留言、拍砖~

 

PPT链接 视频链接

更多内容,可以加入IT交流群565734203与大家一起讨论交流

这里是技能树·IT修真院:,初学者转行到互联网的聚集地

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


摘要: 原创出处 https://www.bysocket.com 「公众号:泥瓦匠BYSocket 」欢迎关注和转载,保留摘要,谢谢! 目录 连接 连接池产生原因 连接池实现原理 小结 TEMPERANCE:Eat not to dullness;drink not to elevation.节制
摘要: 原创出处 https://www.bysocket.com 「公众号:泥瓦匠BYSocket 」欢迎关注和转载,保留摘要,谢谢! 一个优秀的工程师和一个普通的工程师的区别,不是满天飞的架构图,他的功底体现在所写的每一行代码上。-- 毕玄 1. 命名风格 【书摘】类名用 UpperCamelC
今天犯了个错:“接口变动,伤筋动骨,除非你确定只有你一个人在用”。哪怕只是throw了一个新的Exception。哈哈,这是我犯的错误。一、接口和抽象类类,即一个对象。先抽象类,就是抽象出类的基础部分,即抽象基类(抽象类)。官方定义让人费解,但是记忆方法是也不错的 —包含抽象方法的类叫做抽象类。接口
Writer :BYSocket(泥沙砖瓦浆木匠)微 博:BYSocket豆 瓣:BYSocketFaceBook:BYSocketTwitter :BYSocket一、引子文件,作为常见的数据源。关于操作文件的字节流就是 —FileInputStream&FileOutputStream。
作者:泥沙砖瓦浆木匠网站:http://blog.csdn.net/jeffli1993个人签名:打算起手不凡写出鸿篇巨作的人,往往坚持不了完成第一章节。交流QQ群:【编程之美 365234583】http://qm.qq.com/cgi-bin/qm/qr?k=FhFAoaWwjP29_Aonqz
本文目录 线程与多线程 线程的运行与创建 线程的状态 1 线程与多线程 线程是什么? 线程(Thread)是一个对象(Object)。用来干什么?Java 线程(也称 JVM 线程)是 Java 进程内允许多个同时进行的任务。该进程内并发的任务成为线程(Thread),一个进程里至少一个线程。 Ja
Writer :BYSocket(泥沙砖瓦浆木匠)微 博:BYSocket豆 瓣:BYSocketFaceBook:BYSocketTwitter :BYSocket在面向对象编程中,编程人员应该在意“资源”。比如?1String hello = "hello"; 在代码中,我们
摘要: 原创出处 https://www.bysocket.com 「公众号:泥瓦匠BYSocket 」欢迎关注和转载,保留摘要,谢谢! 这是泥瓦匠的第103篇原创 《程序兵法:Java String 源码的排序算法(一)》 文章工程:* JDK 1.8* 工程名:algorithm-core-le
摘要: 原创出处 https://www.bysocket.com 「公众号:泥瓦匠BYSocket 」欢迎关注和转载,保留摘要,谢谢! 目录 一、父子类变量名相同会咋样? 有个小故事,今天群里面有个人问下面如图输出什么? 我回答:60。但这是错的,答案结果是 40 。我知错能改,然后说了下父子类变
作者:泥瓦匠 出处:https://www.bysocket.com/2021-10-26/mac-create-files-from-the-root-directory.html Mac 操作系统挺适合开发者进行写代码,最近碰到了一个问题,问题是如何在 macOS 根目录创建文件夹。不同的 ma
作者:李强强上一篇,泥瓦匠基础地讲了下Java I/O : Bit Operation 位运算。这一讲,泥瓦匠带你走进Java中的进制详解。一、引子在Java世界里,99%的工作都是处理这高层。那么二进制,字节码这些会在哪里用到呢?自问自答:在跨平台的时候,就凸显神功了。比如说文件读写,数据通信,还
1 线程中断 1.1 什么是线程中断? 线程中断是线程的标志位属性。而不是真正终止线程,和线程的状态无关。线程中断过程表示一个运行中的线程,通过其他线程调用了该线程的 方法,使得该线程中断标志位属性改变。 深入思考下,线程中断不是去中断了线程,恰恰是用来通知该线程应该被中断了。具体是一个标志位属性,
Writer:BYSocket(泥沙砖瓦浆木匠)微博:BYSocket豆瓣:BYSocketReprint it anywhere u want需求 项目在设计表的时候,要处理并发多的一些数据,类似订单号不能重复,要保持唯一。原本以为来个时间戳,精确到毫秒应该不错了。后来觉得是错了,测试环境下很多一
纯技术交流群 每日推荐 - 技术干货推送 跟着泥瓦匠,一起问答交流 扫一扫,我邀请你入群 纯技术交流群 每日推荐 - 技术干货推送 跟着泥瓦匠,一起问答交流 扫一扫,我邀请你入群 加微信:bysocket01
Writer:BYSocket(泥沙砖瓦浆木匠)微博:BYSocket豆瓣:BYSocketReprint it anywhere u want.文章Points:1、介绍RESTful架构风格2、Spring配置CXF3、三层初设计,实现WebService接口层4、撰写HTTPClient 客户
Writer :BYSocket(泥沙砖瓦浆木匠)什么是回调?今天傻傻地截了张图问了下,然后被陈大牛回答道“就一个回调…”。此时千万个草泥马飞奔而过(逃哈哈,看着源码,享受着这种回调在代码上的作用,真是美哉。不妨总结总结。一、什么是回调回调,回调。要先有调用,才有调用者和被调用者之间的回调。所以在百
Writer :BYSocket(泥沙砖瓦浆木匠)一、什么大小端?大小端在计算机业界,Endian表示数据在存储器中的存放顺序。百度百科如下叙述之:大端模式,是指数据的高字节保存在内存的低地址中,而数据的低字节保存在内存的高地址中,这样的存储模式有点儿类似于把数据当作字符串顺序处理:地址由小向大增加
What is a programming language? Before introducing compilation and decompilation, let's briefly introduce the Programming Language. Programming la
Writer :BYSocket(泥沙砖瓦浆木匠)微 博:BYSocket豆 瓣:BYSocketFaceBook:BYSocketTwitter :BYSocket泥瓦匠喜欢Java,文章总是扯扯Java。 I/O 基础,就是二进制,也就是Bit。一、Bit与二进制什么是Bit(位)呢?位是CPU
Writer:BYSocket(泥沙砖瓦浆木匠)微博:BYSocket豆瓣:BYSocket一、前言 泥瓦匠最近被项目搞的天昏地暗。发现有些要给自己一些目标,关于技术的目标:专注很重要。专注Java 基础 + H5(学习) 其他操作系统,算法,数据结构当成课外书博览。有时候,就是那样你越是专注方面越