关系数据库的范式理论_数据库规范化理论依据

关系数据库的范式理论_数据库规范化理论依据文章目录求关系模式最高达到第几范式的步骤通俗理解1NF,2NF,3NF.如何求关系模式的候选码如何求闭包函数依赖求关系模式最高达到第几范式的步骤根据给定的U和F,首先求它的候选码根据候选码判断关系F中的函数关系是否满足第二范式,若不满足则为关系模式的规范化最高为第一范式然后判断是否存在非主属性传递依赖,如果存在则不满足第二范式,如果不存在则关系模式的规范化最高为第三范式.通俗理解1N…

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE稳定放心使用

求关系模式最高达到第几范式的步骤

  1. 根据给定的U和F,首先求它的候选码
  2. 根据候选码判断关系F中的函数关系是否满足第二范式,若不满足则为关系模式的规范化最高为第一范式
  3. 然后判断是否存在非主属性传递依赖,如果存在则不满足第二范式,如果不存在则关系模式的规范化最高为第三范式.

通俗理解1NF,2NF,3NF.

  • 1NF的定义:

     一个关系模式R的所有属性都是不可分的基本数据项.
    

    1NF容易理解就不多解释了,在这里举两道简单的题帮助理解.

    1. 规范化的关系模式中,所有属性都必须是( C)。
      A.相互关联的
      B.互不关联的
      C.不可分解的
      D长度可变的
    2. 关系数据库中的每个关系必须最低到达__第一范式__,且该范式中的每个属性都是__不可再分__的。
  • 2NF的定义:

     在1NF的基础上,关系中每一个非主属性完全函数依赖于码. 
     所以满足第二范式则一定满足第一范式.
     对这个非主属性完全函数依赖于码不清楚可以看最后**函数依赖中的图**来理解.
    
  • 3NF的定义:

     在满足2NF的基础上,满足每个非主属性既不部分依赖于码也不传递依赖于码.
    满足3NF的同时一定满足2NF.
    

如何求关系模式的候选码

  • 首先对于给定的R(U)和函数依赖集F,可以将它的属性化分为4类:
  • L类:仅出现在F的函数依赖左部的属性.
  • R类:仅出现在F的函数依赖右部的属性.
  • N类:在F的函数依赖左部和右部未出现的属性.
  • LR类:在F的函数依赖左部和右部均出现那的属性.

下图的题中:A->C
C->A
B->AC
D->AC
L:找出这些式子中在箭头左边的
R:找出式子在
出现在箭头右边的
N:找出所有的R中既没有出现箭头在左边又没有出现在箭头右边的
LR:找出既出现在箭头左边又出现在箭头右边的

如下图所示.

那么求出这些L,R,N,LR类后我们根据三个定理来确定候选码的成员:

  • 定理1:对于给定的关系模式R以及其函数依赖集F,若X(x∈R)是L类,则X必为R的任一候选码的成员.
  • 定理2:对于给定的关系模式R以及其函数依赖集F,若X(x∈R)是R类,则X不在任何候选码中.
  • 定理3:设有关系模式R以及函数依赖集F,如果X是R的N类属性,则X必包含在R的任一候选码中.
  • 推论2:如果X是R的N类和L类组成的属性集,且X+包含了所有的属性,则X是R的唯一候选码.

简单的来说就是对于在 L和N类中的都是候选码的成员:
在这里插入图片描述
确定了候选码的成员后如何确定最后的候选码呢?我们看到上面有这个B+或者(BD)+这在求B的闭包,下面我们来了解以下如何求闭包吧.

如何求闭包

闭包就是由一个属性直接或间接推导出所有属性的集合.引用: http://blog.sina.com.cn/s/blog_7f6c91720101jkhm.html.了解了闭包的概念后我们要学会如何求闭包,
步骤如下:
属性集的闭包步骤
在这里插入图片描述
当我们求出所由候选码成员的闭包后,我们根据上面的推论2,

  • 推论2:如果X是R的N类和L类组成的属性集,且X+包含了所有的属性,则X是R的唯一候选码.
    假设上图中BC为候选码的成员,求到的(BC)+的闭包为ABCE;
    而U={A,B,C,D,E},并没有全部包含所有属性,所以它不是关系模式R的码.

F={A->E,AC->B,B->A,D->A,D->C}
下面我来求一下D的闭包(D)f+

根据D->A,D->c将A,C 目前(D)+=ACD;
(ACD)={A,C,D,AD,AC,CD}
A->E AC->B 变成(D)f+=(ABCDE)

(D)f+包含了R中的所有属性,所以D为R的码.

函数依赖

求出码后我们就根据2NF,3NF中的函数依赖来判断关系模式的规范化最高为?
1.这个中AB为候选码,但是存在非主属性依赖于B,不满足所有非主属性完全依赖于码.在这里插入图片描述

2.再看一道题
在这里插入图片描述
最后总结两个常考的知识点

  1. 在一个关系R中,若X→Y,并且X的任何真子集都不能函数决定Y,则称X→Y为___完全___函数依赖
  2. 若X→Y,并且X的一个真子集也能够函数决定Y,则称X→Y为___部分___函数依赖。
  3. 一个关系模式R中的候选码可能有多个.
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/181231.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • linux如何卸载jdk_怎么卸载JDK

    linux如何卸载jdk_怎么卸载JDK介绍了如何在Linux环境中卸载JDK的方法。

    2022年10月1日
    3
  • 常量表达式是什么_const常量

    常量表达式是什么_const常量常量表达式值(constant-expressionvalue)。通常情况下,常量表达式值必须被一个常量表达式赋值,而跟常量表达式函数一样,常量表达式值在使用前必须被初始化。一、常量表达式1.1运行时常量性与编译时常量性在C++中,我们常常会遇到常量的概念。常量表示该值不可修改,通常是通过const关键字来修饰的。比如:constinti=3;const还可以修饰函数参数、函数返回值、函数本身、类等。在不同的使用条件下,const有不同的意义,不过大多数情况下,const描述的都

    2022年9月27日
    4
  • WIFI 常识

    WIFI 常识DSSS(DirectSequenceSpreadSpectrum)直接序列扩频FHSS,跳频技术(Frequency-HoppingSpreadSpectrum)FHSS和DSSS比较跳频扩频(FHSS):跳频扩频(FHSS)技术是通过“伪随机码”的调制,信息的载波受一伪随机序列的控制,使载波工作的中心频率不断跳跃改变,而噪音和干扰信号的中心频率却不会改变,这样,只要收、发信机之间按照固定的数字算法产生相同的“伪随机码”,就可以达到同步,排除了噪音和其它干扰信号。虽然在..

    2022年7月20日
    12
  • 解决pycharm中使用pip安装numpy失败的问题「建议收藏」

    解决pycharm中使用pip安装numpy失败的问题「建议收藏」今天使用pycharm编译python程序时,由于要调用numpy包,但又未曾安装numpy,于是就根据pycharm的提示进行安装,最后竟然提示出错!!!如下图:这不是要让我回归命令行的生活吗?!解决方案如下:1、下载numpy-1.19.5-cp39-cp39-win_amd64.whl,网址是https://pypi.org/project/numpy/#files2、将下载好的numpy文件放在python安装路径下的/scripts中3、在命令行状态下切换到script

    2022年8月29日
    7
  • 最近公共祖先_洛谷好不好

    最近公共祖先_洛谷好不好原题链接题目描述如题,给定一棵有根多叉树,请求出指定两个点直接最近的公共祖先。输入格式第一行包含三个正整数 N,M,SN,M,S,分别表示树的结点个数、询问的个数和树根结点的序号。接下来 N-1N−1 行每行包含两个正整数 x, yx,y,表示 xx 结点和 yy 结点之间有一条直接连接的边(数据保证可以构成树)。接下来 MM 行每行包含两个正整数 a, ba,b,表示询问 aa 结点和 bb 结点的最近公共祖先。输出格式输出包含 MM 行,每行包含一个正整数,依次为每一个询问的结果。输入

    2022年8月8日
    7
  • mac idea 2021.5 激活码【在线注册码/序列号/破解码】

    mac idea 2021.5 激活码【在线注册码/序列号/破解码】,https://javaforall.net/100143.html。详细ieda激活码不妨到全栈程序员必看教程网一起来了解一下吧!

    2022年3月18日
    51

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号