MySQL主表与副表级联操作及多表查询(两张独立表,一张关系表)

本文主要是介绍MySQL主表与副表级联操作及多表查询(两张独立表,一张关系表),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

MySQL中主表与副表的区别,级联操作的运用

在这里插入图片描述

划重点:

1 被约束的表称为副表,约束别人的表称为主表,外键设置在副表上的。
2 主表被参考的字段通常都设置为主键
3 当有外键约束的时候,添加数据的顺序:先加主表,再添加副表的数据
4 当有外键约束的时候,修改数据的顺序:先修改副表,再修改主表的数据
5 当有外键约束的时候,删除数据的顺序:先删除副表,再删除主表的数据

级联操作

当有外键约束的时候,必须先修改或删除副表中的所有关联数据,才能修改或删除主表!但是,我们希望直接修改或删除主表数据,从而影响副表数据,这时候,我们就用到了级联操作,只需要在副表中添加一句:

ON UPDATE CASCADE  
  • 1

如下图:

在这里插入图片描述

 

 

Mysql多表查询(两张独立表,一张关系表)

一、数据库设计

1、三个数据表长这样

 

其中user表记录用户信息,cat主要记录男女性别,mete表是用户id和性别id的对应关系

 

2、具体数据如下

 

二、查询目标

查询出所有性别为“男”的用户的“姓名”,如下记录两种不同形式的查询

1、单纯的条件查询

SQL:

select user.value from user where user.uid in (select mete.uid from mete where mete.cid=1) 

 

结果:

 

语句解释:

先使用select mete.uid from mete where mete.cid=1语句在mete表中,查找到所有“男”的uid(这里默认我们已经知道cid=1代表男性),再通过条件查询,与上句查询结果进行比对,从而显示出user表中的所有男性名字。

 

2、使用连接查询,条件显示所有用户的姓名和对应的性别

SQL:

select U.value,C.value from mete as M join cat as C on C.cid=M.cid join user as U on U.uid=M.uid 

 

结果:

语句解释:使用到了内联查询,只输出包含连接条件的数据行,从左往右看,可以理解为先将mete表与cat表连接,通过条件C.cid=M.cid,形成了一个性别类型匹配的新表,新表再和user表连接,通过U.uid=M.uid ,形成了一个姓名匹配的表,此时这三张表就联合形成了一个性别类型、名称类型一一对应的表,长得是这样,

再通过select语句,选出了我们想要的姓名和性别对应的表。

 

注:如上是内联查询,只输出满足所有条件的数据,也可以通过外联查询,不对数据过滤,只对数据组合的新表

SQL:

select * from mete as M left join cat as C on C.cid=M.cid left join user as U on U.uid=M.uid 

语句解释:在join前加left/right,则可以使用外联查询,不同的是连接的表组和后输出左表(右表)中不符合条件的记录,如下

这篇关于MySQL主表与副表级联操作及多表查询(两张独立表,一张关系表)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

使用Dify访问mysql数据库详细代码示例

《使用Dify访问mysql数据库详细代码示例》:本文主要介绍使用Dify访问mysql数据库的相关资料,并详细讲解了如何在本地搭建数据库访问服务,使用ngrok暴露到公网,并创建知识库、数据库访... 1、在本地搭建数据库访问的服务,并使用ngrok暴露到公网。#sql_tools.pyfrom

MySQL中实现多表查询的操作方法(配sql+实操图+案例巩固 通俗易懂版)

《MySQL中实现多表查询的操作方法(配sql+实操图+案例巩固通俗易懂版)》本文主要讲解了MySQL中的多表查询,包括子查询、笛卡尔积、自连接、多表查询的实现方法以及多列子查询等,通过实际例子和操... 目录复合查询1. 回顾查询基本操作group by 分组having1. 显示部门号为10的部门名,员

MyBatis-Plus中静态工具Db的多种用法及实例分析

《MyBatis-Plus中静态工具Db的多种用法及实例分析》本文将详细讲解MyBatis-Plus中静态工具Db的各种用法,并结合具体案例进行演示和说明,具有很好的参考价值,希望对大家有所帮助,如有... 目录MyBATis-Plus中静态工具Db的多种用法及实例案例背景使用静态工具Db进行数据库操作插入

MySQL中COALESCE函数示例详解

《MySQL中COALESCE函数示例详解》COALESCE是一个功能强大且常用的SQL函数,主要用来处理NULL值和实现灵活的值选择策略,能够使查询逻辑更清晰、简洁,:本文主要介绍MySQL中C... 目录语法示例1. 替换 NULL 值2. 用于字段默认值3. 多列优先级4. 结合聚合函数注意事项总结C

通过ibd文件恢复MySql数据的操作方法

《通过ibd文件恢复MySql数据的操作方法》文章介绍通过.ibd文件恢复MySQL数据的过程,包括知道表结构和不知道表结构两种情况,对于知道表结构的情况,可以直接将.ibd文件复制到新的数据库目录并... 目录第一种情况:知道表结构第二种情况:不知道表结构总结今天干了一件大事,安装1Panel导致原来服务

mysql关联查询速度慢的问题及解决

《mysql关联查询速度慢的问题及解决》:本文主要介绍mysql关联查询速度慢的问题及解决方案,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录mysql关联查询速度慢1. 记录原因1.1 在一次线上的服务中1.2 最终发现2. 解决方案3. 具体操作总结mysql

Linux搭建Mysql主从同步的教程

《Linux搭建Mysql主从同步的教程》:本文主要介绍Linux搭建Mysql主从同步的教程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录linux搭建mysql主从同步1.启动mysql服务2.修改Mysql主库配置文件/etc/my.cnf3.重启主库my

MySql中的数据库连接池详解

《MySql中的数据库连接池详解》:本文主要介绍MySql中的数据库连接池方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录mysql数据库连接池1、概念2、为什么会出现数据库连接池3、原理4、数据库连接池的提供商5、DataSource数据源6、DBCP7、C

MySQL的隐式锁(Implicit Lock)原理实现

《MySQL的隐式锁(ImplicitLock)原理实现》MySQL的InnoDB存储引擎中隐式锁是一种自动管理的锁,用于保证事务在行级别操作时的数据一致性和安全性,本文主要介绍了MySQL的隐式锁... 目录1. 背景:什么是隐式锁?2. 隐式锁的工作原理3. 隐式锁的类型4. 隐式锁的实现与源代码分析4

SpringBoot操作MaxComputer方式(保姆级教程)

《SpringBoot操作MaxComputer方式(保姆级教程)》:本文主要介绍SpringBoot操作MaxComputer方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的... 目录引言uqNqjoe一、引入依赖二、配置文件 application.properties(信息用自己