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


    文章目录

    • 一、三大范式
    • 二、举例说明
      • 1NF
      • 2NF
      • 3NF


    提示:以下是本篇文章正文内容,Java系列学习将会持续更新

    一、三大范式

    范式是数据库设计时遵循的一种规范,不同的规范要求遵循不同的范式。

    最常用的三大范式:

    第一范式(1NF):属性不可分割,即每个属性都是不可分割的原子项。(实体的属性即表中的列)

    第二范式(2NF):满足第一范式;且不存在部分依赖,即非主属性必须完全依赖于主属性。(主属性即主键;完全依赖是针对于联合主键的情况,非主键列不能只依赖于主键的一部分)

    第三范式(3NF):满足第二范式;且不存在传递依赖,即非主属性不能与非主属性之间有依赖关系,非主属性必须直接依赖于主属性,不能间接依赖主属性。(A -> B, B ->C, A -> C)

    回到目录…

    二、举例说明

    1NF

    不符合第一范式的表:属性还可以再分割

    idnamemessage
    001张三13岁,五年级
    002李四14岁,六年级
    003王五15岁,七年级

    修改后的表:每个字段原子性,不可再分割

    idnameageclass
    001张三13岁五年级
    002李四14岁六年级
    003王五15岁七年级

    回到目录…

    2NF

    在满足1NF的前提下,表中不存在部分依赖,非主键列要完全依赖于主键。(主要是说在联合主键的情况下,非主键列不能只依赖于主键的一部分)

    注意:这张表中的stu_id和kc_id构成了联合主键。score没问题,它完全依赖于联合主键,stu_id和kc_id两个值才能决定score的值。但是kc_name只依赖于kc_id,这是部分依赖关系,不符合第二范式。

    stu_id (学号)kc_id (课程号)score (分数)kc_name (课程名)
    00110185高数
    00110279C语言
    00210179高数

    修改后的表:分为两张表,每张表都符合第二范式。

    stu_id (学号)kc_id (课程号)score (分数)
    00110185
    00110279
    00210179
    kc_id (课程号)kc_name (课程名)
    101高数
    102C语言

    回到目录…

    3NF

    在满足2NF的前提下,不存在传递依赖。(A -> B, B -> C, A->C)

    sex_desc不直接依赖于主键,而是通过依赖于非主键列而依赖于主键,属于传递依赖,不符合3NF。(id -> sex_code -> sex_desc)

    idnamesex_codesex_descphone
    001张三1男178XXXXXXXX
    002李四1男177XXXXXXXX
    003王五0女188XXXXXXXX

    修改后的表:分为两张表,每张表都符合第三范式。

    idnamesex_codephone
    001张三1178XXXXXXXX
    002李四1177XXXXXXXX
    003王五0188XXXXXXXX
    sex_codesex_desc
    1男
    0女

    回到目录…


    总结:
    提示:这里对文章进行总结:
    以上就是今天的学习内容,本文是MySQL的学习,认识了数据库的三大范式,并且可以分辨表属于第几范式。之后的学习内容将持续更新!!!

  • 相关阅读:
    shell_74.Linux创建使用函数
    Flink和Kafka连接时的精确一次保证
    Docker监控方案(TIG)的研究与实践之Influxdb
    Java版直播商城免 费 搭 建:电商、小程序、三级分销及免 费 搭 建,平台规划与营销策略全掌握
    php如何处理高并发请求
    offsetof宏计算某变量相对于首地址的偏移量
    【物理应用】基于Matlab实现LBM-D2Q9模型粗糙界面流动
    【亲测非常好用系统开发工具】勤哲 Excel 服务器2017 V13.0.144 最好用稳定版本,带注册,无限用户,含教程
    DNS域名解析过程
    C++ 里面lambda和函数指针的转换
  • 原文地址:https://blog.csdn.net/qq15035899256/article/details/126315832
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | 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号