【MySQL】表的设计

系列文章目录

第一章 数据库基础

第二章 数据库基本操作

第三章数据库约束


文章目录


前言

在前文中,我们学会了基本的CRUD操作,对数据库中的数据进行约束以提高数据库的准确性。接下来介绍的表的设计就是尝试将场景转化成数据库中的内容知识。


一、表的设计

设计表需要考虑许多部分,实体、关系等一系列因素都会影响到表的创建。

设计表通常有这么几个步骤:

  1. 确定场景中的实体
  2. 理清楚实体之间的关系

二、表的关系

1.一对一

实体之间只存在于一对一的关系是十分常见的。

以简单的教务系统来说,一个学生只有一个账号,一个账号只属于一个学生。我们可以有以下两种设计形式。

[1] 在一张表中有学生的基本信息,同时还有账号的信息。(这种情况下当信息量大了之后就会复杂许多)

[2] 设计两张表 student表中有学生的基本信息,account表中存储账号的基本信息。二者之间可以通过外键进行连接。在student表中加上accountId;在account 表中加上studentId

2.一对多

一对多的关系以学生和班级进行举例即可。一个学生只存在于一个班级,而一个班级里有多个学生。

在这种情况下,班级表就不能有studentId的存在了,而学生表中应当有一列属于classId 作为外键连接

3. 多对多

一个学生可以学习多个课程,而一个课程可以有多个学生学习。这种情况就是最简单的多对多的情形。

对于这种情况,我们通常会引入一个"关联表"

student(id,name ......);

course(courseId,courseName ......);

student_course(studentId,courseId);

这种情况下,通过student_course表存储两个外键.
4.无关系


总结

表的设计就像设计模式一样,通过一些基本的表之间的关系,给我们基本的思路让我们能够更快的设计表。

相关推荐
小光学长3 分钟前
基于vue框架的宠物销售管理系统3m9h3(程序+源码+数据库+调试部署+开发环境)系统界面在最后面。
数据库
小菜yh27 分钟前
关于Redis
java·数据库·spring boot·redis·spring·缓存
Microsoft Word1 小时前
数据库系统原理(第一章 数据库概述)
数据库·oracle
华为云开源1 小时前
openGemini 社区人才培养计划:助力成长,培养新一代云原生数据库人才
数据库·云原生·开源
小安运维日记3 小时前
Linux云计算 |【第四阶段】NOSQL-DAY1
linux·运维·redis·sql·云计算·nosql
kejijianwen4 小时前
JdbcTemplate常用方法一览AG网页参数绑定与数据寻址实操
服务器·数据库·oracle
编程零零七4 小时前
Python数据分析工具(三):pymssql的用法
开发语言·前端·数据库·python·oracle·数据分析·pymssql
高兴就好(石7 小时前
DB-GPT部署和试用
数据库·gpt
这孩子叫逆8 小时前
6. 什么是MySQL的事务?如何在Java中使用Connection接口管理事务?
数据库·mysql
Karoku0668 小时前
【网站架构部署与优化】web服务与http协议
linux·运维·服务器·数据库·http·架构