zoukankan      html  css  js  c++  java
  • 数据库三大范式和五大约束

    数据库的三大范式:

    第一范式:数据库表的每一列都是不可分割的基本数据项,同一列中不能有多个值。

    第二范式:先满足第一范式,实体中每一行的所有非主属性都必须完全依赖于主键。

    第三范式:先满足第二范式,实体中的属性不能是其他实体中的非主属性。即数据库中每一列数据都和主键直接相关,而不能间接相关。

    下面举例来解释三大范式。

    例如用户信息表中有 地址 这个属性,如果 地址 属性中 城市 部分需要被经常访问,那么就要 地址 这个属性重新拆分为省份、城市、详细地址等多个部分,这样设计才算满足了数据库的第一范式。

    假如有个订单信息表,这个表是以 订单编号 和 商品编号 作为联合主键。这个表中商品名称、单位等信息不与该表的主键相关,而仅仅是与商品编号相关。合理的做法是将这张表中商品信息分离到另一个表中,将订单号也分离到另一个表中,这样才算满足数据库的第二范式。

    例如在设计一个订单表,可以将客户编号作为一个外键和订单表建立相应的关系,不可以在订单表中添加关于客户其他信息的字段,这样才算满足数据库的第三范式。

    数据库中的五大约束:

    主键约束(Primay Key Constraint)唯一性,非空性

    唯一约束(Unique Constraint)唯一性,可以空,但只能有一个

    默认约束(Default Constraint)该数据的默认值

    外键约束(Foreign Key Constraint)需要建立两表间的关系

    非空约束(Not Null Constraint)该字段不能为空

    参考:

    https://www.cnblogs.com/zhouguowei/p/9268788.html

  • 相关阅读:
    纯CSS实现垂直居中的几种方法
    用定位实现机器人效果
    Java 集合 HashMap & HashSet 拾遗
    Java 集合 持有引用 & WeakHashMap
    Java 泛型 通配符类型
    多线程threading 的使用
    mysql 数据库的设计三范式
    python 排序算法
    Python 中的单例模式
    mysql 数据库引擎
  • 原文地址:https://www.cnblogs.com/colin220/p/11433197.html
Copyright © 2011-2022 走看看