码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 数据库三大范式


    为什么要数据规范化

    • 信息重复
    • 更新异常
    • 插入异常
      • 无法正常显示信息
    • 删除异常
      • 丢失有效信息

    三大范式

      第一范式(1NF)

    • 原子性:保证每一列不可再分
    • 关系模式中的所有属性值都是不可再分的原子值

             在上面的表中,“家庭信息”和“学校信息”列均不满足原子性的要求,故不满足第一范式,调整如下:

      第二范式(2NF)

    • 前提:满足第一范式

    • 第二范式需要确保数据库表中的每一列都和主键相关,而不能只与主键的某一部分相关(主要针对联合主键而言)

    • 即满足第一范式,且关系模式的任一非主属性都完全函数依赖与任一候选码

             在上图所示的情况中,同一个订单中可能包含不同的产品,因此主键必须是"订单号"和"产品号"联合组成,但可以发现,产品数量、产品折扣、产品价格与'订单号"和"产品号"都相关,但是订单金额和订单时间仅与"订单号“相关,与"产品号"无关这样就不满足第二范式的要求,调整如下,需分成两个表:

    第三范式(3NF)

    • 前提:满足第一范式和第二范式
    • 第三范式需要确保数据表中的每一列数据都和主键直接相关,而不能间接相关。
    • 即满足第一、第二范式且不传递依赖于候选码

            上表中,所有属性都完全依赖于学号,所以满足第二范式,但是“班主任性别”和“班主任年龄”直接依赖的是“班主任姓名”,而不是主键“学号”,所以需做如下调整:

    BC范式(扩展)

    • 不存在主属性候选码有部分/传递依赖

    规范性和性能的问题

    关联查询不得超过三张表

    • 考虑商业化的需求和目标(成本,用户体验)数据库的性能更加重要
    • 在规范性能的问题的时候,需要适当的考虑一下规范性
    • 故意给某些表增加一些冗余的字段。(从多表查询中变为单表查询)
    • 故意增加一些计算列(从大数据库降低为小数据量的查询:索引)

  • 相关阅读:
    paddle 36 paddledetection替换backbone(如使用hrnet_w64,swin_l_p4_w12等模型)
    LeetCode220902_93、搜索二维矩阵 II
    Cocos2dx-js 资源.jsc和.pkm反编译
    使用fread,fwrite函数完成文件的复制
    【Luogu】 P5643 [PKUWC2018] 随机游走
    Page分页records有数据,但是total=0,解决办法
    前端基础面试题 简单复杂数据类型检测转换、阶乘、绝对值、圣诞...
    Python基础知识从hello world 开始(第二天)
    Linux多线程
    2023-06-10 Untiy进阶 C#知识补充1——.Net介绍
  • 原文地址:https://blog.csdn.net/weixin_48426115/article/details/126260037
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号