zoukankan      html  css  js  c++  java
  • SQL 数据库设计 三范式 3NF


    一个好的高效的数据库必需要好的设计,范式的好处就是,(优点)减少数据冗余;减少数据的空间;减轻维护数据库的麻烦;

    (缺点)但是操作困难;需要联合多张表一起查询;越高的范式性越能差;  范式也要权衡是否使用更高的范式麻烦!

    【注意:一般在项目中用到的是第三范式,已经足够满足需求,性能也基本满足】

    第一范式: 数据库表每一列数据都是不可分割的基本数据列;同一列不能有多个值 ,或者重复值。(每个数据项都是原子项,不可分割)

    第二范式:范级理论是逐级递增的过程,即满足第一范式,而且这个表中的非主键字段都依赖这个表的主键,即满足第二范式2NF;

    (如果非主键,而且不依赖本表,则应该抽出一张独立表出来,依赖外键!以减少数据冗余!第二范式消除部门依赖!)

    第三范式:满足第二范式2NF;所有非主键对任务后选关键字都不存在传递依赖,即为第三范式3NF;

    简单的说,
    第一范式就是列的原子性,字段不可再分割;
    第二范式就是完全依赖,没有部分依赖;
    第三范式就是没有传递依赖。

  • 相关阅读:
    SVN为什么比Git更好
    vim的高亮查找操作
    Mac利用PD虚拟机安装Centos7
    学习MapReduce的计算原理
    hadoop-HA高可用集群部署
    HDFS命令操作和高可用
    初识hadoop及伪集群部署
    初步学习nginx
    小记--------maxwell启动失败解决
    小记--------spark资源调度机制源码分析-----Schedule
  • 原文地址:https://www.cnblogs.com/p_db/p/2379605.html
Copyright © 2011-2022 走看看