【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 分钟前
MySQL数据库 意向锁(初篇)
数据库·mysql
阿拉伯柠檬4 分钟前
MySQL基本查询
linux·数据库·mysql·面试
蜂蜜黄油呀土豆10 分钟前
深入理解 MySQL 架构:主从复制、延迟治理与分库分表设计
mysql·binlog·分库分表·主从复制·高并发系统设计
semantist@语校14 分钟前
第五十七篇|东京银星日本语学校的数据建模:高密度城市中的学习节律、制度边界与 Prompt 接口设计
大数据·数据库·人工智能·学习·百度·prompt·知识图谱
风月歌15 分钟前
基于小程序的超市购物系统设计与实现源码(java+小程序+mysql+vue+文档)
java·mysql·微信小程序·小程序·毕业设计·源码
TDengine (老段)23 分钟前
携手桂冠电力、南网储能、中能拾贝,TDengine 三项案例入选“星河奖”
大数据·数据库·物联网·时序数据库·tdengine·涛思数据
阿坤带你走近大数据23 分钟前
Oracle中如何监控SQL执行时间?
数据库·sql·oracle
乘凉~24 分钟前
【Linux作业】CentOS 7下MySQL数据库安装与数据导入实操项目报告
linux·数据库·centos
q行28 分钟前
MySQL学习日志--表之间的关系
数据库·学习·mysql
MoonBit月兔33 分钟前
海外开发者实践分享:用 MoonBit 开发 SQLC 插件(其三)
java·开发语言·数据库·redis·rust·编程·moonbit