当前位置: 首页 > news >正文

【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.无关系


总结

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

相关文章:

  • 北京网站建设多少钱?
  • 辽宁网页制作哪家好_网站建设
  • 高端品牌网站建设_汉中网站制作
  • ECMAScript6语法:类
  • 常见编码形式特征汇总(1)
  • 数据库根据日期统计SQL编写记录
  • c语言-经典例题
  • Redis 为什么这么快?
  • Ant Design Vue 快速上手指南 + 排坑
  • 单片机内存映射
  • wtv-next 宝塔更新教程
  • 计算数学精解【14】-Maxima计算精解【2】
  • VUE3请求意外报跨越错误或者500错误问题
  • 前端内容简单记录
  • Elasticsearch核心概念:
  • 【Linux —— 线程控制】
  • 电子合同如何在线签?9大协助工具软件
  • Python之字符串操作(连接符、重复符、比较、in)
  • [译]如何构建服务器端web组件,为何要构建?
  • Flex布局到底解决了什么问题
  • java8-模拟hadoop
  • JavaScript 基础知识 - 入门篇(一)
  • Java读取Properties文件的六种方法
  • Java多态
  • leetcode388. Longest Absolute File Path
  • 第13期 DApp 榜单 :来,吃我这波安利
  • 工作踩坑系列——https访问遇到“已阻止载入混合活动内容”
  • 诡异!React stopPropagation失灵
  • 前端面试题总结
  • 树莓派 - 使用须知
  • 微信如何实现自动跳转到用其他浏览器打开指定页面下载APP
  • 一起来学SpringBoot | 第三篇:SpringBoot日志配置
  • 第二十章:异步和文件I/O.(二十三)
  • 我们雇佣了一只大猴子...
  • ​LeetCode解法汇总2182. 构造限制重复的字符串
  • #1014 : Trie树
  • #鸿蒙生态创新中心#揭幕仪式在深圳湾科技生态园举行
  • (10)STL算法之搜索(二) 二分查找
  • (3)Dubbo启动时qos-server can not bind localhost22222错误解决
  • (创新)基于VMD-CNN-BiLSTM的电力负荷预测—代码+数据
  • (二十四)Flask之flask-session组件
  • (附源码)计算机毕业设计ssm本地美食推荐平台
  • (每日一问)基础知识:堆与栈的区别
  • (转载)VS2010/MFC编程入门之三十四(菜单:VS2010菜单资源详解)
  • .babyk勒索病毒解析:恶意更新如何威胁您的数据安全
  • .Net 8.0 新的变化
  • .net 调用海康SDK以及常见的坑解释
  • .NET/C# 检测电脑上安装的 .NET Framework 的版本
  • /bin/bash^M: bad interpreter: No such file or directory
  • @selector(..)警告提示
  • @WebServiceClient注解,wsdlLocation 可配置
  • [ Python ]使用Charles对Python程序发出的Get与Post请求抓包-解决Python程序报错问题
  • [ 隧道技术 ] 反弹shell的集中常见方式(二)bash反弹shell
  • [【JSON2WEB】 13 基于REST2SQL 和 Amis 的 SQL 查询分析器
  • [20171101]rman to destination.txt
  • [ACTF2020 新生赛]Upload 1
  • [android] 练习PopupWindow实现对话框
  • [C#]使用DlibDotNet人脸检测人脸68特征点识别人脸5特征点识别人脸对齐人脸比对FaceMesh