数据库中范式_数据库 范式

数据库中范式_数据库 范式SQL基础随记3 范式 键 什么是范式?哈,自己设计会使用但是一问还真说不上来。遂将不太明晰的概念整体下 什么是 & 分类 范式(NF),一种规范,设计数据库模型时对关系内部各个属性之

SQL基础随记3 范式 键 - G

SQL基础随记3 范式 键

什么是范式?哈,自己设计会使用但是一问还真说不上来。遂将不太明晰的概念整体下

 

什么是 & 分类

范式(NF),一种规范,设计数据库模型时对关系内部各个属性之间的联系的合理化程度的不同等级的规范要求。

分类:

  • 1NF、2NF、3NF、BCNF(巴斯科德范式)、4NF、5NF(完美范式)

低阶范式是高阶范式的基础,范式等级越高冗余度越低,使用时越容易进行join

 

  • 超键:能唯一表示元组(元组也就是一行数据,一条记录)的属性的集合。超键可能包含多余属性。如身份证号+学生id+姓名
  • 候选键:不包含多余属性的超键。候选键可能不唯一,身份证号或学生id都可以当做候选键。
  • 主键
  • 外键

属性

  • 主属性:任意候选键的属性就是主属性
  • 非主属性

依赖

  • 依赖:一个或一组属性的值决定其他属性的值
  • 完全依赖:某个非主属性于所有主属性
  • 部分依赖
  • 传递依赖:若存在 “A>>B>>C”的依赖关系,则C传递依赖于A

 

Each NF

  • 1NF:表中任何属性都是原子性的(不可拆分的),所有 RDBMS都满足。

  • 2NF:任意一个非主属性都要与主属性/候选键完全依赖。

    若不满足2NF会造成

    • 数据冗余

    • 增删改异常

      不满足2NF举例

      球员id决定球员姓名等球员个人信息

      比赛id决定比赛时间、比赛场地等比赛信息

      若将上述所有属性放在一张表中就会造成

      • 数据冗余:异常比赛有n个球员参加,那么记录该场比赛n个球员信息时,对应的比赛信息就多余了n-1次

      • 增删改异常:仅根据球员id或比赛id进行操作时,

        增:不知道另一个主属性导致无法插入

        删:会删除另一个主属性以及其对应的信息

        改:修改信息时,有改信息的所有记录都要修改

  • 3NF:在第二范式的基础上,任意一个非主属性都不传递依赖于候选键

    不满足3NF但满足2NF举例

    表1:球员id、球员姓名、球队名称、主教练姓名

    球员姓名、球队名称、主教练姓名都可以由球员id决定

    但是主教练姓名也可以通过球队名称决定,这就出现了传递依赖

    如果我们将表1拆分成

    表2:球员id、球员姓名、球队名称

    表3:球队名称、主教练名称

    则满足3NF

 

致命总结

在第一范式的基础上,根据”非主完全依赖主属性”对所有属性进行划分并给每张表加id就满足第二范式,再细分属性消除传递依赖加上FOREIGN KEY就满足第三范式

BCNF、4NF、5NF查询效率极低,很少用到,开发效率和查询效率都很感人。

 

反范式

一般情况下,业务界面会显示用户姓名而不是用户ID,因此常常需要将user表与其他表连接查询。因此当数据量较大时可以将user id 与 use name 在其他常用表中“冗余”,这样可以只进行单表扫描。而不用在大数据量的情况下再连接查询。

反范式在OLAP场景比较常用,详见此处另见此处

数据库中范式_数据库 范式

 

 

反范式设计与数据仓库

数据仓库与数据库的区别:

  • 数据库用于捕获数据,数据仓库用于分析数据
  • 数据库对增删改实时性要求强,需要存储在线的用户数据。数据仓库一般是历史数据
  • 数据库要尽量避冗余,数据仓库的设计上更偏向反范式设计,因为历史数据往往很多。连接查询会大幅度拖慢速度。

 

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

(0)
上一篇 2023-03-17
下一篇 2023-03-18

相关推荐

  • Pirhun: Python编写爬虫程序的利器

    Pirhun: Python编写爬虫程序的利器Pirhun是一个Python编写的爬虫框架,它提供了简单易懂的API,可以帮助开发者快速构建爬虫程序。它可以支持多线程、异步IO,还提供了强大的数据处理能力,能够帮助你高效地爬取各种网站的数据。

    2023-12-19
    64
  • 从创建索引过程中内存变化来看SQL Server与MySQL的内存淘汰算法[亲测有效]

    从创建索引过程中内存变化来看SQL Server与MySQL的内存淘汰算法[亲测有效]在sqlserver中,几年之前就注意到一个现象:sqlserver中对一个大表创建索引或者rebuild索引的过程中,会引起内存剧烈的动荡,究其原因为何,这种现象到底正不正常,是不是sqlserve

    2023-02-20
    102
  • ORACLE统计字符串出现的次数[通俗易懂]

    ORACLE统计字符串出现的次数[通俗易懂]在ORACLE数据库的使用中,有时候我们需要统计某个字符串出现的次数。 但是在11g版本前,我们需要结合translate函数可以完成,比较麻烦,例如统计“/”在字符串中出现的次数: SELECT …

    2022-12-20
    109
  • mysql-5.7.21

    mysql-5.7.211 、 下载对用的版本信息 地址是:https://dev.mysql.com/downloads/mysql/ 2 、 解压到目录 D: oolsmysqlmysql-5.7.21-winx6

    2022-12-28
    107
  • Python Class用于面向对象编程

    Python Class用于面向对象编程Python是一种简单易学的高级编程语言,常用于数据分析、机器学习、人工智能等领域。Python是一种面向对象的编程语言,具有强大的面向对象编程特性。Python中的Class是实现面向对象编程的重要组成部分,一个Class可以包含多个属性和方法,可以用来创建对象。下面将从多个方面对Python Class用于面向对象编程进行详细的阐述。

    2024-03-23
    31
  • cloudera hadoop大数据平台实战指南_Hadoop

    cloudera hadoop大数据平台实战指南_Hadoop一、概述 在众多 Hadoop 版本中, CDH(Cloudera Hadoop) 是 Hadoop 众多分支中比较出色的版本, 它由Cloudera 发行和维护。CDH 基于 Apache 的 Ha

    2023-05-17
    98
  • [20220106]ora-00600 kokasgi1.txt

    [20220106]ora-00600 kokasgi1.txt[20220106]ora-00600 kokasgi1.txt–//上午看了https://www.xifenfei.com/2022/01/2022-first-recovery-ora-600

    2023-05-04
    99
  • 如何用C++自己实现mysql数据库的连接池?[通俗易懂]

    如何用C++自己实现mysql数据库的连接池?[通俗易懂]为什么是mysql? 现在几乎所有的后台应用都要用到数据库,什么关系型的、非关系型的;正当关系的,不正当关系的;主流的和非主流的, 大到Oracle,小到sqlite,以及包括现在逐渐流行的基于物联网

    2023-04-19
    112

发表回复

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