【Java 进阶篇】MySQL多表关系详解
MySQL是一种常用的关系型数据库管理系统,它允许我们创建多个表格,并通过各种方式将这些表格联系在一起。在实际的数据库设计和应用中,多表关系是非常常见的,它能够更好地组织和管理数据,实现数据的复杂查询和分析。本文将详细介绍MySQL多表关系的基本概念、类型、设计原则以及常见应用场景。
1. 为什么需要多表关系?
在数据库设计中,有时候一个单独的表格无法满足数据存储和查询的需求,这时就需要使用多表关系。多表关系的引入有以下几个主要原因:
-
数据的规范性: 数据库的设计需要满足规范化的原则,避免数据冗余和不一致。多表关系可以帮助我们将数据划分成逻辑上的单元,每个表格负责存储特定类型的数据。
-
数据的复杂性: 随着业务的发展,数据的复杂性也增加了。多表关系可以更好地组织和管理数据,使数据更容易维护和查询。
-
查询的灵活性: 多表关系使得查询变得更加灵活,可以轻松地进行跨表查询和分析,从而获得更有价值的信息。
2. 多表关系的基本概念
在MySQL中,多表关系可以通过不同的方式来实现,主要包括以下几种类型:
2.1. 一对一关系
一对一关系是指两个表格之间的关系,其中一个表格的每一行对应另一个表格的一行,而且每一行都有唯一的匹配项。这种关系通常用于将数据分解成更小的逻辑单元。
示例: 一个公司的员工表格和工资表格可以建立一对一关系,每个员工只有一个工资记录。
2.2. 一对多关系
一对多关系是指一个表格的每一行对应另一个表格的多行,但另一个表格的每一行只对应一个表格的一行。这种关系通常用于描述一对多的关联。
示例: 一个部门表格和一个员工表格可以建立一对多关系,一个部门可以有多名员工,但每名员工只属于一个部门。
2.3. 多对多关系
多对多关系是指一个表格的每一行对应另一个表格的多行,反之亦然。这种关系通常用于描述多对多的关联。
示例: 一个学生表格和一个课程表格可以建立多对多关系,一个学生可以选择多门课程,而一门课程也可以有多名学生选修。
3. 多表关系的设计原则
在设计多表关系时,需要遵循一些基本原则,以确保数据的完整性和查询性能:
3.1. 规范化
规范化是数据库设计的基本原则,它可以减少数据冗余、提高数据的一致性,并简化数据的维护。在多表关系中,每个表格应该负责存储一个特定类型的数据,避免将不同类型的数据混合在同一个表格中。
3.2. 主键和外键
主键和外键是建立多表关系的关键。主键用于唯一标识表格中的每一行数据,而外键用于建立不同表格之间的关联关系。通常情况下,外键是一个表格中的字段,它引用了另一个表格中的主键字段。这样可以建立表格之间的联系,实现数据的关联查询。
3.3. 索引
为了提高多表关系查询的性能,可以在表格的关联字段上创建索引。索引可以加快查询速度,特别是在大型数据集上。
3.4. 数据完整性约束
为了保持数据的完整性,可以使用数据完整性约束,如唯一约束、默认约束、检查约束等。这些约束可以确保数据的一致性,避免不合法的数据插入或更新。
4. 常见应用场景
以下是一些常见应用场景的示例代码,演示了如何在MySQL数据库中使用多表关系来管理数据。这些场景包括电子商务、学校管理系统和社交媒体平台。
1. 电子商务网站 - 订单和产品
在电子商务网站中,通常需要管理订单和产品之间的关系。一个订单可以包含多个产品,而一个产品可以出现在多个订单中。这是一个典型的多对多关系。
-- 创建产品表
CREATE TABLE Products (product_id INT PRIMARY KEY,product_name VARCHAR(255),price DECIMAL(10, 2)
);-- 创建订单表
CREATE TABLE Orders (order_id INT PRIMARY KEY,order_date DATE
);-- 创建订单-产品关联表
CREATE TABLE OrderProducts (order_id INT,product_id INT,quantity INT,PRIMARY KEY (order_id, product_id),FOREIGN KEY (order_id) REFERENCES Orders(order_id),FOREIGN KEY (product_id) REFERENCES Products(product_id)
);
2. 学校管理系统 - 学生和课程
在学校管理系统中,学生可以注册多门课程,而一门课程也可以有多名学生。这是一个多对多关系。
-- 创建学生表
CREATE TABLE Students (student_id INT PRIMARY KEY,student_name VARCHAR(255)
);-- 创建课程表
CREATE TABLE Courses (course_id INT PRIMARY KEY,course_name VARCHAR(255)
);-- 创建学生-课程关联表
CREATE TABLE StudentCourses (student_id INT,course_id INT,PRIMARY KEY (student_id, course_id),FOREIGN KEY (student_id) REFERENCES Students(student_id),FOREIGN KEY (course_id) REFERENCES Courses(course_id)
);
3. 社交媒体平台 - 用户和帖子
在社交媒体平台中,用户可以发布多个帖子,而一个帖子也可以有多个用户参与(评论、点赞等)。这是一个多对多关系。
-- 创建用户表
CREATE TABLE Users (user_id INT PRIMARY KEY,username VARCHAR(255)
);-- 创建帖子表
CREATE TABLE Posts (post_id INT PRIMARY KEY,post_content TEXT
);-- 创建用户-帖子关联表(发布帖子)
CREATE TABLE UserPosts (user_id INT,post_id INT,PRIMARY KEY (user_id, post_id),FOREIGN KEY (user_id) REFERENCES Users(user_id),FOREIGN KEY (post_id) REFERENCES Posts(post_id)
);-- 创建评论表
CREATE TABLE Comments (comment_id INT PRIMARY KEY,comment_content TEXT
);-- 创建用户-评论关联表(评论帖子)
CREATE TABLE UserComments (user_id INT,comment_id INT,PRIMARY KEY (user_id, comment_id),FOREIGN KEY (user_id) REFERENCES Users(user_id),FOREIGN KEY (comment_id) REFERENCES Comments(comment_id)
);
4. 图书管理系统 - 图书和作者
下面是一个简单的示例代码,演示了一个图书管理系统中的多表关系。系统包括两个表格,一个是"图书"表格,另一个是"作者"表格。每本书可以有一个或多个作者,这是一个多对多关系。
CREATE TABLE Books (book_id INT PRIMARY KEY,book_title VARCHAR(255),publication_year INT
);CREATE TABLE Authors (author_id INT PRIMARY KEY,author_name VARCHAR(255)
);CREATE TABLE BookAuthors (book_id INT,author_id INT,PRIMARY KEY (book_id, author_id),FOREIGN KEY (book_id) REFERENCES Books(book_id),FOREIGN KEY (author_id) REFERENCES Authors(author_id)
);
在上述示例中,"BookAuthors"表格用于建立"图书"表格和"作者"表格之间的多对多关系。每个记录表示一本书和一个作者之间的关系。
这些示例代码演示了在MySQL中如何创建多表关系以支持不同应用场景的需求。这些关联表用于建立多对多关系,确保数据的一致性和完整性。在实际应用中,您可以根据需求进行修改和扩展。
5. 总结
多表关系是数据库设计中的重要概念,它可以帮助我们更好地组织和管理数据,实现复杂的数据查询和分析。了解多表关系的基本概念、设计原则和常见应用场景对于数据库设计和应用开发都非常重要。通过合理设计多表关系,可以提高数据库的性能和数据的一致性,为应用提供更好的支持。
作者信息 作者 : 繁依Fanyi CSDN: https://techfanyi.blog.csdn.net 掘金:https://juejin.cn/user/4154386571867191 |
相关文章:

【Java 进阶篇】MySQL多表关系详解
MySQL是一种常用的关系型数据库管理系统,它允许我们创建多个表格,并通过各种方式将这些表格联系在一起。在实际的数据库设计和应用中,多表关系是非常常见的,它能够更好地组织和管理数据,实现数据的复杂查询和分析。本文…...

【开发篇】十、Spring缓存:手机验证码的生成与校验
文章目录 1、缓存2、用HashMap模拟自定义缓存3、SpringBoot提供缓存的使用4、手机验证码案例完善 1、缓存 缓存是一种介于数据永久存储介质与数据应用之间的数据临时存储介质使用缓存可以有效的减少低速数据读取过程的次数(例如磁盘IO),提高…...

【Aurora 8B/10B IP(1)--初步了解】
Aurora 8B/10B IP(1)–初步了解 1 Aurora 8b/10b IP的基本状态: •通用数据通道吞吐量范围从480 Mb/s到84.48 Gb/s •支持多达16个连续粘合7GTX/GTH系列、UltraScale™ GTH或UltraScale+™ GTH收发器和4绑定GTP收发器 •Aurora 8B/10B协议规范v2.3顺从的 •资源成本低(请参…...
C++ vector容器的介绍与使用
一、vector简介 std::vector 是 C 标准模板库 (STL) 中的一个动态数组容器。允许存储元素(可以使用任何数据类型作为其元素类型)集合,并能够动态调整其大小。 特点: 动态大小:与常规数组不同,vector 可以…...
openstack的组成
OpenStack 是一个开源的云计算平台,由一系列组件构成,各组件之间相互协作,提供了完整的基础设施即服务(IaaS)解决方案。下面详细解释了 OpenStack 的主要组件及其相互关系: Nova(计算服务&…...

[React] React高阶组件(HOC)
文章目录 1.Hoc介绍2.几种包装强化组件的方式2.1 mixin模式2.2 extends继承模式2.3 HOC模式2.4 自定义hooks模式 3.高阶组件产生初衷4.高阶组件使用和编写结构4.1 装饰器模式和函数包裹模式4.2 嵌套HOC 5.两种不同的高阶组件5.1 正向的属性代理5.2 反向的继承 6.如何编写高阶组…...

【逐步剖C++】-第二章-C++类和对象(中)
前言:本章继【逐步剖C】-第二章-C类和对象(上)介绍有关类和对象更深层次的知识点,这里是文章导图: 本文较长,内容较多,大家可以根据需求跳转到自己感兴趣的部分,希望能对读者有一些帮…...
PL/SQL动态SQL
目录 1. 动态 sql 2. 带参数的动态 sql -- 不使用 USING 传参 1. 动态 sql -- 在 PL/SQL 程序开发中,可以使用 DML 语句,但是很多语句(如 DDL),不能直接在 PL/SQL中执行,这些语句可以使用动态 sql 来实现. 语法格式: EXECUTE IMMEDIATE --动态语句的字符串 [into 变量…...

Python绘图系统24:添加辅助坐标轴
文章目录 辅助坐标增减坐标轴时间轴**代码优化源代码 Python绘图系统: 前置源码: Python打造动态绘图系统📈一 三维绘图系统 📈二 多图绘制系统📈三 坐 标 轴 定 制📈四 定制绘图风格 📈五 数据…...
Java自学网站--十几个网站的分析与评测
原文网址:Java自学网站--十几个网站的分析与评测_IT利刃出鞘的博客-CSDN博客 简介 很多想学Java的人不知道怎样选教程,本文对Java自学网站进行评测。 本文不带主观倾向,只客观分析各个网站的区别。 第1类:大型培训机构(黑马等…...
java接口怎么写
Java接口是一种定义规范的抽象类型,可以包含常量和方法的声明。接口在Java编程中具有重要的作用,可以实现代码的重用和灵活性。本文将详细介绍Java接口的编写方式和使用方法。 一、什么是Java接口 在Java中,接口(Interface&…...

第8章 Spring(二)
8.11 Spring 中哪些情况下,不能解决循环依赖问题 难度:★★ 重点:★★ 白话解析 有一下几种情况,循环依赖是不能解决的: 1、原型模式下的循环依赖没办法解决; 假设Girl中依赖了Boy,Boy中依赖了Girl;在实例化Girl的时候要注入Boy,此时没有Boy,因为是原型模式,每次都…...
从0开始python学习-24.selenium 浏览器常见的操作
1. 浏览器的最大化/最小化:maximize_window () / minimize_window() 2. 设置浏览器的宽高:set_window_size() 3. 设置浏览器的位置:set_window_position(0,0) —》左上角为原点 4. 刷新:refresh() 5. 前进:forward() 6…...

Canal实现数据同步
1、Canal实现数据同步 canal可以用来监控数据库数据的变化,从而获得新增数据,或者修改的数据。 1.1 Canal工作原理 原理相对比较简单: 1、canal模拟mysql slave的交互协议,伪装自己为mysql slave,向mysql master发送…...
数据库学习笔记——DDL
数据库学习笔记——DDL 建立EMPLOYEE数据库: CREATE TABLE employee(employee_ID int not null,employee_name varchar(20) not null,street varchar(20) not null,city varchar(20) not null,PRIMARY KEY(employee_ID) );CREATE TABLE company(company_name varc…...
MATLAB算法实战应用案例精讲-【人工智能】边缘计算(附python代码实现)
目录 前言 几个高频面试题目 边缘计算和云计算的关系 云计算(cloud computing) 边缘计算...

精彩回顾 | 迪捷软件亮相2023世界智能网联汽车大会
2023年9月24日,2023世界智能网联汽车大会(以下简称大会)在北京市圆满落幕。迪捷软件北京参展之行圆满收官。 本次大会由工业和信息化部、公安部、交通运输部、中国科学技术协会、北京市人民政府联合主办,是我国首个经国务院批准的…...
【ShaderLab PBR 嗜血边缘角色_美式朋克风格_“Niohoggr“_角色渲染(第一篇)】
嗜血边缘角色Cyberpunk style Unity 渲染 《嗜血边缘》截取其中的片段如下:资源分析其中Guitar贴图4张模型:人物细节图:人物模型 Inspector面板这里做一个区域区分:Body贴图1_BC贴图1_BC属性:Body贴图2_NBody贴图3_CMBody贴图4_SRMBody贴图4_RGBReflection Probe第一版Sha…...
python经典百题之围圈报数
题目:有n个人围成一圈,顺序排号。从第一个人开始报数(从1到3报数),凡报到3的人退出圈子,问最后留下的是原来第几号的那位。 程序分析 思路1:模拟游戏过程 使用一个循环队列模拟游戏过程,每次循…...
Google Earth Engine(GEE)案例——如何去除和过滤Landsat和sentinel等系列影像集合中的空影像(三种方法)
简介 本文的主要解决的问题是如何去除和过滤Landsat和sentinel等系列影像集合中的空影像?这个主要源于一下的问题: “从图像集中删除空图像”是什么意思?您的脚本将图像集合过滤到没有图像的日期,这会产生包含 0 个图像的图像集合:https: https://code.earthengine.goog…...

深入浅出Asp.Net Core MVC应用开发系列-AspNetCore中的日志记录
ASP.NET Core 是一个跨平台的开源框架,用于在 Windows、macOS 或 Linux 上生成基于云的新式 Web 应用。 ASP.NET Core 中的日志记录 .NET 通过 ILogger API 支持高性能结构化日志记录,以帮助监视应用程序行为和诊断问题。 可以通过配置不同的记录提供程…...

【WiFi帧结构】
文章目录 帧结构MAC头部管理帧 帧结构 Wi-Fi的帧分为三部分组成:MAC头部frame bodyFCS,其中MAC是固定格式的,frame body是可变长度。 MAC头部有frame control,duration,address1,address2,addre…...
基于服务器使用 apt 安装、配置 Nginx
🧾 一、查看可安装的 Nginx 版本 首先,你可以运行以下命令查看可用版本: apt-cache madison nginx-core输出示例: nginx-core | 1.18.0-6ubuntu14.6 | http://archive.ubuntu.com/ubuntu focal-updates/main amd64 Packages ng…...
解锁数据库简洁之道:FastAPI与SQLModel实战指南
在构建现代Web应用程序时,与数据库的交互无疑是核心环节。虽然传统的数据库操作方式(如直接编写SQL语句与psycopg2交互)赋予了我们精细的控制权,但在面对日益复杂的业务逻辑和快速迭代的需求时,这种方式的开发效率和可…...

全球首个30米分辨率湿地数据集(2000—2022)
数据简介 今天我们分享的数据是全球30米分辨率湿地数据集,包含8种湿地亚类,该数据以0.5X0.5的瓦片存储,我们整理了所有属于中国的瓦片名称与其对应省份,方便大家研究使用。 该数据集作为全球首个30米分辨率、覆盖2000–2022年时间…...
MVC 数据库
MVC 数据库 引言 在软件开发领域,Model-View-Controller(MVC)是一种流行的软件架构模式,它将应用程序分为三个核心组件:模型(Model)、视图(View)和控制器(Controller)。这种模式有助于提高代码的可维护性和可扩展性。本文将深入探讨MVC架构与数据库之间的关系,以…...

基于Docker Compose部署Java微服务项目
一. 创建根项目 根项目(父项目)主要用于依赖管理 一些需要注意的点: 打包方式需要为 pom<modules>里需要注册子模块不要引入maven的打包插件,否则打包时会出问题 <?xml version"1.0" encoding"UTF-8…...

push [特殊字符] present
push 🆚 present 前言present和dismiss特点代码演示 push和pop特点代码演示 前言 在 iOS 开发中,push 和 present 是两种不同的视图控制器切换方式,它们有着显著的区别。 present和dismiss 特点 在当前控制器上方新建视图层级需要手动调用…...
Redis:现代应用开发的高效内存数据存储利器
一、Redis的起源与发展 Redis最初由意大利程序员Salvatore Sanfilippo在2009年开发,其初衷是为了满足他自己的一个项目需求,即需要一个高性能的键值存储系统来解决传统数据库在高并发场景下的性能瓶颈。随着项目的开源,Redis凭借其简单易用、…...
Caliper 负载(Workload)详细解析
Caliper 负载(Workload)详细解析 负载(Workload)是 Caliper 性能测试的核心部分,它定义了测试期间要执行的具体合约调用行为和交易模式。下面我将全面深入地讲解负载的各个方面。 一、负载模块基本结构 一个典型的负载模块(如 workload.js)包含以下基本结构: use strict;/…...