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

  • 相关阅读:
    pycharm 代码块缩进、左移
    os.popen(cmd) .read() 获取执行后的结果且带有换行符
    数据分析基础路线了解
    Jupyter中python3之numpy练习
    Mysql数据库操作命令行小结
    Mysql配置主从同步的基本步骤
    百度翻译爬虫-Web版(自动生成sign)
    windows中的常用Dos命令
    Cookie安全隐患DOM演示
    bash漏洞技术层面分析(cgi-bin)
  • 原文地址:https://www.cnblogs.com/colin220/p/11433197.html
Copyright © 2011-2022 走看看