关系型数据库的设计规则详解
E-R(Entity-relationship,实体-联系)模型中有三个主要概念是:实体集、属性、联系集。
一个实体集(class)对应于数据库中的一个表,一个实体(instance)则对应数据库表中的一行,也称一条记录。一个属性对应于数据库表中的一列(column),也称一个字段。
ORM思想(Object Relational Mapping)体现:
数据库表 ↔ Java或Python的一个类
表中的一条数据 ↔ 类中的一个对象(或实体)
表中的一个类 ↔ 类中的一个字段、属性(field)
表关系设计
表与表之间的数据记录有关系(relationship)。现实世界中的各种实体以及实体之间的各种联系均用关系模型来表示。表关系的四种:
1、一对一关联(one-to-one)
在实际的开发中应用不多,因为一对一可以创建成一张表。
举例:设计学生表
:学号、姓名、手机号码、班级、系别、身份证号码、家庭住址、籍贯、紧急联系人、…
拆为两个表:两个表的记录是一一对应关系。
基础信息表
(常用信息):学号、姓名、手机号码、班级、系别档案信息表
(不常用信息):学号、身份证号码、家庭住址、籍贯、紧急联系人、…两种建表原则: 外键唯一:主表的主键和从表的外键(唯一),形成主外键关系,外键唯一。外键是主键:主表的主键和从表的主键,形成主外键关系。
2、一对多关系(one-to-many)
常见实例场景:客户表和订单表
,分类表和商品表
,部门表和员工表
。
举例: 员工表:编号、姓名、…、所属部门部门表:编号、名称、简介 一对多建表原则:在从表(多方)创建一个字段,字段作为外键指向主表(一方)的主键
3、多对多(many-to-many)
要表示多对多关系,必须创建第三个表,该表通常称为联接表
,它将多对多关系划分为两个一对多关系。将这两个表的主键都插入到第三个表中。
举例1:学生-课程
学生信息表
:一行代表一个学生的信息(学号、姓名、手机号码、班级、系别…)
课程信息表
:一行代表一个课程的信息(课程编号、授课老师、简介…)
选课信息表
:一个学生可以选多门课,一门课可以被多个学生选择
学号 课程编号 1 1001 2 1001 1 1002
举例2:产品-订单
“订单”表和“产品”表有一种多对多的关系,这种关系是通过与“订单明细”表建立两个一对多关系来定义的。一个订单可以有多个产品,每个产品可以出现在多个订单中。
产品表
:“产品”表中的每条记录表示一个产品。订单表
:“订单”表中的每条记录表示一个订单。订单明细表
:每个产品可以与“订单”表中的多条记录对应,即出现在多个订单中。一个订单可以与“产品”表中的多条记录对应,即包含多个产品。
举例3:用户-角色
多对多关系建表原则:需要创建第三张表,中间表中至少两个字段,这两个字段分别作为外键指向各自一方的主键。
4、自我引用(Self reference)
到此这篇关于关系型数据库的设计规则详解的文章就介绍到这了,更多相关关系型数据库设计规则内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
Navicat for MySQL导入csv文件时出现中文乱码的问题解决
在做数据对接导入的时候使用的数据是CSV格式的文件,导入发现了乱码,下面这篇文章主要给大家介绍了关于Navicat for MySQL导入csv文件时出现中文乱码的问题解决办法,需要的朋友可以参考下2023-12-12详解Flink同步Kafka数据到ClickHouse分布式表
这篇文章主要为大家介绍了Flink同步Kafka数据到ClickHouse分布式表实现详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪2022-12-12
最新评论