【JavaWeb】Day41.MySQL概述——多表设计(案例)

2024-04-11 17:28

本文主要是介绍【JavaWeb】Day41.MySQL概述——多表设计(案例),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一对一

        一对一关系表通常是用来做单表的拆分,也就是将一张大表拆分成两张小表,将大表中的一些基础字段放在一张表当中,将其他的字段放在另外一张表当中,以此来提高数据的操作效率。

一对一的应用场景: 用户表(基本信息+身份信息)

基本信息:用户的ID、姓名、性别、手机号、学历

身份信息:民族、生日、身份证号、身份证签发机关,身份证的有效期(开始时间、结束时间)

        如果在业务系统当中,对用户的基本信息查询频率特别的高,但是对于用户的身份信息查询频率很低,此时出于提高查询效率的考虑,我就可以将这张大表拆分成两张小表,第一张表存放的是用户的基本信息,而第二张表存放的就是用户的身份信息。他们两者之间一对一的关系,一个用户只能对应一个身份证,而一个身份证也只能关联一个用户。

那么在数据库层面怎么去体现上述两者之间是一对一的关系呢?

       其实一对一我们可以看成一种特殊的一对多。同样我们也可以通过外键来体现一对一之间的关系,我们只需要在任意一方来添加一个外键就可以了。

一对一 :在任意一方加入外键,关联另外一方的主键,并且设置外键为唯一的(UNIQUE)

多对多

       多对多的关系在开发中属于也比较常见的。比如:学生和老师的关系,一个学生可以有多个授课老师,一个授课老师也可以有多个学生。在比如:学生和课程的关系,一个学生可以选修多门课程,一个课程也可以供多个学生选修。

案例:学生与课程的关系

- 关系:一个学生可以选修多门课程,一门课程也可以供多个学生选择

- 实现关系:建立第三张中间表,中间表至少包含两个外键,分别关联两方主键

案例

下面通过一个综合案例加深对于多表关系的理解,并掌握多表设计的流程。

需求:

 1.页面原型-分类管理

        分类的信息:分类名称、分类类型[菜品/套餐]、分类排序、分类状态[禁用/启用]、分类的操作时间(修改时间)。

2.页面原型-菜品管理

         菜品的信息:菜品名称、菜品图片、菜品分类、菜品售价、菜品售卖状态、菜品的操作时间(修改时间)。

3.页面原型-套餐管理

套餐的信息:套餐名称、套餐图片、套餐分类、套餐价格、套餐售卖状态、套餐的操作时间。 

分析 

  • 分析分类与菜品之间是什么关系?

一对多关系。一个分类下会有多个菜品,而一个菜品只能归属一个分类。

设计表原则:在多的一方,添加字段,关联属于一这方的主键。

  • 分析套餐与菜品之间是什么关系?

多对多关系。一个套餐下会有多个菜品,而一个菜品也可以出现在多个套餐中。

设计表原则:创建第三张中间表,建立两个字段分别关联菜品表的主键和套餐表的主键。

  • 分析分类和菜品之间的关系?

一对多的关系。已分类下有多个不同套餐,而一个套餐只能属于一个分类。

设计表原则:在多的一方,添加字段,关联属于一这方的主键。

分析页面原型及需求文档后,我们获得:

  •  分类表

  - 业务字段:分类名称、分类类型、分类排序、分类状态

  - 基础字段:id(主键)、分类的创建时间、分类的修改时间

  •  菜品表

  - 业务字段:菜品名称、菜品图片、菜品分类、菜品售价、菜品售卖状态

  - 基础字段:id(主键)、分类的创建时间、分类的修改时间

  •  套餐表

  - 业务字段:套餐名称、套餐图片、套餐分类、套餐价格、套餐售卖状态

  - 基础字段:id(主键)、分类的创建时间、分类的修改时间

表结构之间的关系:

  •  分类表 - 菜品表 : 一对多

  - 在菜品表中添加字段(菜品分类),关联分类表

  •  菜品表 - 套餐表 : 多对多

  - 创建第三张中间表(套餐菜品关联表),在中间表上添加两个字段(菜品id、套餐id),分别关联菜品表和分类表

表结构

分类表:category

- 业务字段:分类名称、分类类型、分类排序、分类状态

- 基础字段:id(主键)、创建时间、修改时间

-- 分类表
create table category
(id          int unsigned primary key auto_increment comment '主键ID',name        varchar(20)      not null unique comment '分类名称',type        tinyint unsigned not null comment '类型 1 菜品分类 2 套餐分类',sort        tinyint unsigned not null comment '顺序',status      tinyint unsigned not null default 0 comment '状态 0 禁用,1 启用',create_time datetime         not null comment '创建时间',update_time datetime         not null comment '更新时间'
) comment '菜品及套餐分类';

菜品表:dish

- 业务字段:菜品名称、菜品图片、菜品分类、菜品售价、菜品售卖状态

- 基础字段:id(主键)、分类的创建时间、分类的修改时间

~~~mysql
-- 菜品表
create table dish
(id          int unsigned primary key auto_increment comment '主键ID',name        varchar(20)      not null unique comment '菜品名称',category_id int unsigned     not null comment '菜品分类ID',   -- 逻辑外键price       decimal(8, 2)    not null comment '菜品价格',image       varchar(300)     not null comment '菜品图片',description varchar(200) comment '描述信息',status      tinyint unsigned not null default 0 comment '状态, 0 停售 1 起售',create_time datetime         not null comment '创建时间',update_time datetime         not null comment '更新时间'
) comment '菜品';
~~~

套餐表:setmeal

- 业务字段:套餐名称、套餐图片、套餐分类、套餐价格、套餐售卖状态

- 基础字段:id(主键)、分类的创建时间、分类的修改时间

~~~mysql
-- 套餐表
create table setmeal
(id          int unsigned primary key auto_increment comment '主键ID',name        varchar(20)      not null unique comment '套餐名称',category_id int unsigned     not null comment '分类id',       -- 逻辑外键price       decimal(8, 2)    not null comment '套餐价格',image       varchar(300)     not null comment '图片',description varchar(200) comment '描述信息',status      tinyint unsigned not null default 0 comment '状态 0:停用 1:启用',create_time datetime         not null comment '创建时间',update_time datetime         not null comment '更新时间'
) comment '套餐';
~~~

套餐菜品关联表:setmeal_dish

~~~mysql
-- 套餐菜品关联表
create table setmeal_dish
(id         int unsigned primary key auto_increment comment '主键ID',setmeal_id int unsigned     not null comment '套餐id ',    -- 逻辑外键dish_id    int unsigned     not null comment '菜品id',     -- 逻辑外键copies     tinyint unsigned not null comment '份数'
) comment '套餐菜品关联表';
~~~

这篇关于【JavaWeb】Day41.MySQL概述——多表设计(案例)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/894723

相关文章

Java实现将HTML文件与字符串转换为图片

《Java实现将HTML文件与字符串转换为图片》在Java开发中,我们经常会遇到将HTML内容转换为图片的需求,本文小编就来和大家详细讲讲如何使用FreeSpire.DocforJava库来实现这一功... 目录前言核心实现:html 转图片完整代码场景 1:转换本地 HTML 文件为图片场景 2:转换 H

Java使用jar命令配置服务器端口的完整指南

《Java使用jar命令配置服务器端口的完整指南》本文将详细介绍如何使用java-jar命令启动应用,并重点讲解如何配置服务器端口,同时提供一个实用的Web工具来简化这一过程,希望对大家有所帮助... 目录1. Java Jar文件简介1.1 什么是Jar文件1.2 创建可执行Jar文件2. 使用java

SpringBoot实现不同接口指定上传文件大小的具体步骤

《SpringBoot实现不同接口指定上传文件大小的具体步骤》:本文主要介绍在SpringBoot中通过自定义注解、AOP拦截和配置文件实现不同接口上传文件大小限制的方法,强调需设置全局阈值远大于... 目录一  springboot实现不同接口指定文件大小1.1 思路说明1.2 工程启动说明二 具体实施2

Java实现在Word文档中添加文本水印和图片水印的操作指南

《Java实现在Word文档中添加文本水印和图片水印的操作指南》在当今数字时代,文档的自动化处理与安全防护变得尤为重要,无论是为了保护版权、推广品牌,还是为了在文档中加入特定的标识,为Word文档添加... 目录引言Spire.Doc for Java:高效Word文档处理的利器代码实战:使用Java为Wo

SpringBoot日志级别与日志分组详解

《SpringBoot日志级别与日志分组详解》文章介绍了日志级别(ALL至OFF)及其作用,说明SpringBoot默认日志级别为INFO,可通过application.properties调整全局或... 目录日志级别1、级别内容2、调整日志级别调整默认日志级别调整指定类的日志级别项目开发过程中,利用日志

Java中的抽象类与abstract 关键字使用详解

《Java中的抽象类与abstract关键字使用详解》:本文主要介绍Java中的抽象类与abstract关键字使用详解,本文通过实例代码给大家介绍的非常详细,感兴趣的朋友跟随小编一起看看吧... 目录一、抽象类的概念二、使用 abstract2.1 修饰类 => 抽象类2.2 修饰方法 => 抽象方法,没有

SpringBoot 多环境开发实战(从配置、管理与控制)

《SpringBoot多环境开发实战(从配置、管理与控制)》本文详解SpringBoot多环境配置,涵盖单文件YAML、多文件模式、MavenProfile分组及激活策略,通过优先级控制灵活切换环境... 目录一、多环境开发基础(单文件 YAML 版)(一)配置原理与优势(二)实操示例二、多环境开发多文件版

Spring 中的切面与事务结合使用完整示例

《Spring中的切面与事务结合使用完整示例》本文给大家介绍Spring中的切面与事务结合使用完整示例,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考... 目录 一、前置知识:Spring AOP 与 事务的关系 事务本质上就是一个“切面”二、核心组件三、完

Java实现远程执行Shell指令

《Java实现远程执行Shell指令》文章介绍使用JSch在SpringBoot项目中实现远程Shell操作,涵盖环境配置、依赖引入及工具类编写,详解分号和双与号执行多指令的区别... 目录软硬件环境说明编写执行Shell指令的工具类总结jsch(Java Secure Channel)是SSH2的一个纯J

JavaScript中比较两个数组是否有相同元素(交集)的三种常用方法

《JavaScript中比较两个数组是否有相同元素(交集)的三种常用方法》:本文主要介绍JavaScript中比较两个数组是否有相同元素(交集)的三种常用方法,每种方法结合实例代码给大家介绍的非常... 目录引言:为什么"相等"判断如此重要?方法1:使用some()+includes()(适合小数组)方法2