加入收藏 | 设为首页 | 会员中心 | 我要投稿 开发网_新乡站长网 (https://www.0373zz.com/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > MySql教程 > 正文

MySQL之数据库表的设计

发布时间:2022-12-20 11:14:52 所属栏目:MySql教程 来源:
导读:  MySQL之数据库表的设计

  一、表与表关系分类 1.一对多

  一对多,例如:一个班级对应多名学生(客户和订单、分类和商品)

  建表原则: 主外键的关系。 在从表(多方)创建一个字段,字段作为外键
  MySQL之数据库表的设计
 
  一、表与表关系分类 1.一对多
 
  一对多,例如:一个班级对应多名学生(客户和订单、分类和商品)
 
  建表原则: 主外键的关系。 在从表(多方)创建一个字段,字段作为外键指向主表(一方)的主键
 
  2.多对多
 
  多对多, 例如:一名老师对应多名学生,一名学生又对应多名老师  (学生和课程、用户和角色)
 
  建表原则: 借助中间表,拆分为两个一对多。 创建第三张表,中间表中至少两个字段,这两个字段分别作为外键指向各自一方的主键。
 
  3.一对一
 
  一对一,例如: 一个人只能对应一个身份证ID。在实际开发中使用不多,因为一对一可以设计成一张表。
 
  建表原则:
 
  1.外键唯一   特殊的一对多,主表的主键和从表的外键(唯一),形成主外键关系,外键唯一 UNIQUE
 
  2.外键又是主键 主表的主键和从表的主键,形成主外键关系
 
  二、表与表关系设计 1.创建四张表
 
  1.商品分类表 category
 
  2.商品表 goods
 
  3.用户表 user
 
  4.收藏中间表 favorite
 
  2.表间关系分析:
 
  分类表与商品表是一对多关系(一个分类对应多个商品)
 
  商品表与用户表是多对多关系(一个商品可以被多个用户收藏,一个用户可以收藏多个商品)
 
  商品表与收藏中间表是一对多(一个商品可以被收藏多次)
 
  用户表与收藏中间表是一对多(一个用户可以收藏多次不同商品)
 
  3.设计例子
 
   -- 创建分类表 category
 
   -- cid 分类主键,自动增长
 
   -- cname 分类名称非空,唯一
 
   CREATE TABLE category (
 
   cid INT PRIMARY KEY AUTO_INCREMENT,
 
   cname VARCHAR(100) NOT NULL UNIQUE
 
   );

   -- 创建商品表 goods
 
   -- gid 商品主键,自动增长
 
   -- gname 商品名称非空,唯一
 
   -- price 商品价格
 
   -- cid 外键,所属分类
 
   CREATE TABLE goods(
 
   gid INT PRIMARY KEY AUTO_INCREMENT,
 
   gname VARCHAR(100) NOT NULL UNIQUE,
 
   price DOUBLE,
 
   cid INT,
 
   FOREIGN KEY (cid) REFERENCES category(cid)
 
   );
 
   -- 创建用户表 user
 
   -- uid 用户主键,自增长
 
   -- username 唯一,非空
 
   -- password 非空
 
   -- name 姓名
 
   -- sex 性别
 
   -- phone 手机号

   CREATE TABLE user (
 
   uid INT PRIMARY KEY AUTO_INCREMENT,
 
   username VARCHAR(100) UNIQUE NOT NULL,
 
   PASSWORD VARCHAR(30) NOT NULL,
 
   NAME VARCHAR(20),
 
   sex CHAR(1) DEFAULT '未定义',
 
   phone VARCHAR(11),
 
   );
 
   -- 创建收藏中间表 favorite
 
   -- gid 商品id,外键
 
   -- uid 用户id,外键
 
   -- gid 和 uid 设置为联合主键,同一个用户不能收藏同一个商品两次

   CREATE TABLE favorite (
 
   gid INT, -- 商品id
 
   uid INT, -- 用户id
 
   PRIMARY KEY(gid,uid), -- 联合主键
 
   FOREIGN KEY (gid) REFERENCES goods(gid),
 
   FOREIGN KEY(uid) REFERENCES user(uid)
 
   );

  三、数据库范式 1.什么是范式?
 
  设计关系数据库时,遵从不同的规范要求,设计出合理的关系型数据库,这些不同的规范要求被称为不同的范式mysql数据表,各种范式呈递次规范,越高的范式数据库冗余越小。
 
  目前关系数据库有六种范式:第一范式(1NF)、第二范式(2NF)、第三范式(3NF)、巴斯-科德范式(BCNF)、第四范式(4NF)和第五范式(5NF,又称完美范式)
 
  2.函数依赖
 
  1. 函数依赖:A-->B,如果通过A属性(属性组)的值,可以确定唯一B属性的值。则称B依赖于A

  2. 完全函数依赖:A-->B, 如果A是一个属性组,则B属性值得确定需要依赖于A属性组中所有的属性值。
 
  3. 部分函数依赖:A-->B, 如果A是一个属性组,则B属性值得确定只需要依赖于A属性组中某一些值即可。
 
  4. 传递函数依赖:A-->B, B -- >C . 如果通过A属性(属性组)的值,可以确定唯一B属性的值,在通过B属性(属性组)的值可以确定唯一C属性的值,则称 C 传递函数依赖于A
 
  5. 码:如果在一张表中,一个属性或属性组,被其他所有属性所完全依赖,则称这个属性(属性组)为该表的码
 
  3.三大范式
 
  目前关系数据库有六种范式:第一范式(1NF)、第二范式(2NF)、第三范式(3NF)、巴斯-科德范式(BCNF)、第四范式(4NF)和第五范式(5NF,又称完美范式)。满足最低要求的范式是第一范式(1NF)。在第一范式的基础上进一步满足更多规范要求的称为第二范式(2NF),其余范式以次类推。一般来说,数据库只需满足第三范式(3NF)就行了
 
  1.第一范式(1NF)
 
  所谓第一范式(1NF)是指在关系模型中,对于添加的一个规范要求,所有的域都应该是原子性的,即数据库表的每一列都是不可分割的原子数据项,而不能是集合,数组,记录等非原子数据项。即实体中的某个属性有多个值时,必须拆分为不同的属性。在符合第一范式(1NF)表中的每个域值只能是实体的一个属性或一个属性的一部分。简而言之,第一范式就是无重复的域。
 
  1. 数据库表的每一列都是不可分割的原子数据项,不能是集合、数组等非原子数据项。即表中的某个列有多个值时,必须拆分为不同的列。
 
  2. 简言之,第一范式每一列不可再拆分,称为原子性。
 
  2.第二范式(2NF )
 
  在1NF的基础上,非码属性必须完全依赖于候选码(在1NF基础上消除非主属性对主码的部分函数依赖)
 
  1.在满足第一范式的前提下,表中的每一个字段都完全依赖于主键。
 
  2.简言之,第二范式就是所有列完全依赖于主键列。
 
  3.第三范式(3NF)
 
  在2NF基础上,任何非主属性不依赖于其它非主属性(在2NF基础上消除传递依赖)
 
  1.在满足第二范式的前提下,表中的每一列都直接依赖于主键,而不是通过其它的列来间接依赖于主键。
 
  2.简言之,第三范式就是所有列不依赖于其它非主键列,任何非主列不得传递依赖于主键。
 
  3.三大范式概括
 
  1NF 原子性:表中每列不可再拆分。
 
  2NF 不产生局部依赖,所有列完全依赖于主键列。
 
  3NF 不产生传递依赖,表中每一列都直接依赖于主键。而不是通过其它列间接依赖于主键
 
 

(编辑:开发网_新乡站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!