MySQL-----多表操作



介绍

        实际开发中,一个项目通常需要很多张表才能完成。例如:一个商城项目就需要分类表(category)、商品表(products)、订单表(orders)等多张表。且这些表的数据之间存在一定的关系,接下来我们将在单表的基础上,一起学习多表方面的知识。

一  多表关系

        MySQL多表之间关系可以概括为:一对一,一对多/多对一,多对多。

 ▶ 一对一关系

▣  一个学生只有一张身份证;一张身份证只能对应一学生。

▣  在任一表中添加唯一外键,指向另一方主键,确保一对一关系。

▣  一般一对一关系很少见,遇到一对一关系的表做好是合并表。

 ▶ 一对多关系/多对一关系

比如:部门和员工

分析:一个部门可以有多个员工,一个员工只能对应一个部门。

实现原则:在多的一方建立外键,指向一的一方的主键。

  ▶ 多对多关系

比如:学生和课程

分析:一个学生可以选择很多课程,一个课程也可以被很多学生选择。

原则:多对多关系实现需要借助第三张中间表。中间表至少包含两个字段,将多对多的关系,拆成一对多的关系,中间表至少要有两个外键,这两个外键分别指向原来那两张表的主键。



二  外键约束

介绍

        MySQL外键约束(FOREIGNKEY)是表的一个特殊字段,经常与主键约束一起使用。对于两个具有关联关系的表而言,相关联字段中主键所在的表就是主表(父表),外键所在的表就是从表(子表)。
        外键用来建立主表与从表的关联关系,为两个表的数据建立连接,约束两个表中数据的一致性和完整性。比如,一个水果摊,只有苹果、桃子、李子、西瓜等4种水果,那么,你来到水果摊要买水果就只能选择苹果、桃子、李子和西瓜,其它的水果都是不能购买的。

 ▶ 特点

定义一个主键时,需要遵守下列规则:

1.主表必须已经存在于数据库中,或者是当前正在创建的表。

2.必须为主表定义主键。

3.主键不能包含空值,但允许在外键中出现空值。也就是说,只要外键的每个非空值出现在指定的主键中,这个外键的内容就是正确的。

4.在主表的表名后面指定列明或列明组合。这个列或列的组合必须是主表的主键或候选键。

5.外键中列的数目必须和主表的主键中列的数目相同。

6.外键中列的数据必须和主表主键中对应的数据类型相同。


2-1.一对多关系

1.创建外键约束

 方式一:在创建表时设置外键约束

        constraint <外键名> foreign foreign key 字段名 [,字段名2,...] references <主表名> 主键列1 [,主键列2,...]

 方式一:在创建表后设置外键约束

        alter table <数据表名> add constraint <外键名> foreign key (<列名>) references <主表名> (<列名>);

 示例演示


2.操作外键约束数据

 1.插入数据

2.删除数据

 

 


3.删除外键约束

        当一个表不需要外键约束时,就需要从表中将其删除。外键一旦删除,就会解除主表和从表的关联关系。

语法格式:
        alter table <表名> drop foreign key <外键约束名>;

 



2-2.多对多关系

         在多对多关系中,A表的一行对应B的多行,B表的一行对应A表的多行,我们要新增加一个中间表,来建立多对多关系。

 1.创建多对多的关系

        创建两个主表和一个从表,为从表添加外键约束。

 

2.修改或删除表

         修改和删除表与上述的一对多的关系的操作语法一样,中间表(从表)可以随便删除和修改,但是两边的主表受从表依赖的数据不能删除或者修改。

 



三  多表联合查询

 介绍

        多表查询就是同时查询两个或两个以上的表,因为有的时候用户在查看数据的时候需要显示的数据来自多张表.多表查询有以下分类:

 ▶ 交叉连接查询[产生笛卡尔积,了解]
     语法: select * from A,B;        


 ▶ 内连接查询(使用的关键字inner join -- inner可以省略)


    隐式内连接(SQL92标准) : select * from A,B where条件;
    显示内连接(SQL99标准) : select * from A inner join B on条件;


 ▶ 外连接查询(使用的关键字outer join -- outer可以省略)
    左外连接:left outer join


        select* from A left outer join B on条件;
    右外连接: right outer join


        select * from A right outer join B on条件;
    满外连接: full outer join


        select * from A full outer join B on条件;


 ▶ 子查询
    select的嵌套


 ▶ 表自关联:
    将一张表当成多张表来用 

数据准备

1.交叉连接查询

 ▶ 简介

交叉连接查询返回被连接的两个表所有数据行的笛卡尔积。
笛卡尔积可以理解为一张表的每一行去和另外一张表的任意一行进行匹配。

假如A表有m行数据,B表有n行数据,则返回m*n行数据。
笛卡尔积会产生很多冗余的数据,后期的其他查询可以在该集合的基础上进行条件筛选。
 

  ▶ 格式

        select * from 表1,表2,表3....

  演示

 


2.内连接查询

 内连接查询求多张表的交集:

▶ 格式

隐式内连接(SQL92标准) : select * from A,B where条件;

显示内连接(SQL99标准) : select * from A inner join B on条件;

▶ 演示

 


3.外连接查询

        外连接分为左外连接(left outer join)、右外连接(right outer join),满外连接(full outer join)。

        注意: oracle里面有full join,可是在mysql对full join支持的不好。我们可以使用union来达到目。

 ▶ 格式

left:主要显示左表内容,右表没有的话填充null;

right:主要显示右表内容,左表没有的话填充null;

▶ 演示 


4.子查询

 简介

        子查询就是指的在一个完整的查询语句之中,嵌套若干个不同功能的小查询,从而一起完成复杂查询的一种编写形式,通俗一点就是包含select嵌套的查询。

 特点

子查询可以返回的数据类型一共分为四种:

1.单行单列:返回的是一个具体列的内容,可以理解为一个单值数据;

2.单行多列:返回一行数据中多个列的内容;
3.多行单列:返回多行记录之中同一列的内容,相当于给出了一个操作范围;
4.多行多列:查询返回的结果是一张临时表。

  演示

5.子查询关键字

        在子查询中,有一些常用的逻辑关键字,这些关键字可以给我们提供更丰富的查询功能,主要关键字如下:

1.ALL关键字
2.ANY关键字
3.SOME关键字
4.IN关键字
5.EXISTS关键字

5-1.关键字ALL 

 格式

select ...from ...where c >all(查询语句)
等价于:
select ...from ... where c > resultl and c > result2 and c >result3

▶ 特点

1.ALL:与子查询返回的所有值比较为true则返回true
2.ALL可以与=、>、>=,<、=、<>结合是来使用,分别表示等于、大于、大于等于、小于、小于等于、不等于其中的其中的所有数据。
3.ALL表示指定列中的值必须要大于子查询集的每一个值,即必须要大于子查询集的最大值;如果是小于号即小于子查询集的最小值。同理可以推出其它的比较运算符的情况。

 ▶ 演示


5-2.关键字ANY和SOME

 格式

select ...from ...where  c >any(查询语句)
等价于:
select ...from ... where c > resultl or c > result2 or c >result3

▶ 特点

1.ANY:与子查询返回的任何值比较为true则返回true
2.ANY可以与=、>、>=-、<、<=,<>结合是来使用,分别表示等于、大于、大于等于、小于、小于等于、不等于其中的其中的任何一个数据。
3.表示制定列中的值要大于子查询中的任意一个值,即必须要大于子查询集中的最小值。同理可以推出其它的比较运算符的情况。
4.SOME和ANY的作用一样,SOME可以理解为ANY的别名

 ▶ 演示


 5-3.关键字IN

 格式

select ...from ...where  c in(查询语句)
等价于:
select ...from ... where c = resultl or c = result2 or c = result3

▶ 特点

1.IN关键字,用于判断某个记录的值,是否在指定的集合中.

2.在IN关键字前边加上not可以将条件反过来.

 ▶ 演示

 


  5-3.关键字EXISTS

 格式

select ...from ...where exists(查询语句)

▶ 特点

1.该子查询如果“有数据结果”(至少返回一行数据),则该EXISTS()的结果为“true",外层查询执行
2.该子查询如果“没有数据结果”(没有任何数据返回),则该EXISTS()的结果为“false",外层查询不执行
3.EXISTS后面的子查询不返回任何实际数据,只返回真或假,当返回真时 where条件成立

4.注意,EXISTS关键字,比IN关键字的运算效率高,因此,在实际开发中,特别是大数据量时推荐使用EXISTS关键字

 ▶ 演示

 


6.自关联查询

 ▶ 概念

        MySQL有时在信息查询时需要进行对表自身进行关联查谊,即一张表自己和自己关联,一张表当成多张表来用。注意自关联时表必须给表起别名。

  格式

select    字段列表  from 表1  a , 表1  b  where  条件;

或者
select   字段列表   from 表1 a [left]  join   表1 b  on  条件;

 

   演示

我们先创建一个表使其自关联:
 

 

插入数据:

 自关联查询演示:

 

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/699177.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

使用HiveMQ实现Android MQTT

MQTT官网&#xff1a;https://mqtt.org/ 百度Android MQTT&#xff0c;或者B站上搜索&#xff0c;发现大多使用https://github.com/eclipse/paho.mqtt.android&#xff0c;这是Eclipse的一个Android MQTT客户端实现库&#xff0c;但是我发现这个库在运行到高版本的手机上时报错…

Rust核心:【所有权】相关知识点

rust在内存资源管理上采用了&#xff08;先进优秀&#xff1f;算吗&#xff09;但特立独行的设计思路&#xff1a;所有权。这是rust的核心&#xff0c;贯穿在整个rust语言的方方面面&#xff0c;并以此为基点来重新思考和重构软件开发体系。 涉及到的概念点&#xff1a;借用&am…

使用Postman和JMeter进行signature签名

一、前言 ​ 有些接口的请求会带上sign&#xff08;签名&#xff09;进行请求&#xff0c;各接口对sign的签名内容、方式可能不一样&#xff0c;但一般都是从接口的入参中选择部分内容组成一个字符串&#xff0c;然后再进行签名操作, 将结果赋值给sign; 完整规范的接口文档都会…

Spring Boot与HikariCP:性能卓越的数据库连接池

点击下载《Spring Boot与HikariCP&#xff1a;性能卓越的数据库连接池》 1. 前言 本文将详细介绍Spring Boot中如何使用HikariCP作为数据库连接池&#xff0c;包括其工作原理、优势分析、配置步骤以及代码示例。通过本文&#xff0c;读者将能够轻松集成HikariCP到Spring Boot…

六、回归与聚类算法 - 模型保存与加载

目录 1、API 2、案例 欠拟合与过拟合线性回归的改进 - 岭回归分类算法&#xff1a;逻辑回归模型保存与加载无监督学习&#xff1a;K-means算法 1、API 2、案例

vue : 无法加载文件 C:\Program Files\nodejs\node_global\vue.ps1,因为在此系统上禁止运行脚本。

解决方法&#xff1a; 打开PowerShell&#xff0c;在命令框输入set-ExecutionPolicy RemoteSigned 在PowerShell中输入会出现如下图&#xff0c;输入y即可。

RabbitMQ 部署方式选择

部署模式 RabbitMQ支持多种部署模式&#xff0c;可以根据应用的需求和规模选择适合的模式。以下是一些常见的RabbitMQ部署模式&#xff1a; 单节点模式&#xff1a; 最简单的部署方式&#xff0c;所有的RabbitMQ组件&#xff08;消息存储、交换机、队列等&#xff09;都运行在…

第九节HarmonyOS 常用基础组件28-Select

1、描述 提供下拉选择菜单&#xff0c;可以让用户在多个选项之间选择。 2、接口 Select(options:Array<SelectOption>) 3、SelectOption对象说明 参数名 参数类型 必填 描述 value ResourceStr 是 下拉选项内容。 icon ResourceStr 否 下拉选项图标。 4…

【前端素材】推荐优质后台管理系统Sneat平台模板(附源码)

一、需求分析 后台管理系统是一种用于管理网站、应用程序或系统的工具&#xff0c;它通常作为一个独立的后台界面存在&#xff0c;供管理员或特定用户使用。下面详细分析后台管理系统的定义和功能&#xff1a; 1. 定义 后台管理系统是一个用于管理和控制网站、应用程序或系统…

浏览器录屏技术:探索网页内容的视觉记录之道

title: 浏览器录屏技术&#xff1a;探索网页内容的视觉记录之道 date: 2024/2/23 14:32:49 updated: 2024/2/23 14:32:49 tags: 浏览器录屏技术原理Web API应用场景用户体验在线教育产品演示 在当今数字化时代&#xff0c;浏览器录屏技术已经成为了一种强大的工具&#xff0c;…

​LeetCode解法汇总2583. 二叉树中的第 K 大层和

目录链接&#xff1a; 力扣编程题-解法汇总_分享记录-CSDN博客 GitHub同步刷题项目&#xff1a; https://github.com/September26/java-algorithms 原题链接&#xff1a;. - 力扣&#xff08;LeetCode&#xff09; 描述&#xff1a; 给你一棵二叉树的根节点 root 和一个正整…

Microsoft 365自定义安装软件

如图&#xff0c;在安装类型的步骤的时候&#xff0c;可以勾选自己想要的软件&#xff08;而非一股脑儿的安装一大堆自己不需要的&#xff09;。

HTB pwn Dragon Army

逆向分析 程序使用了alloca函数扩大了栈区 此处可以泄露libc的地址 程序主要功能在下面 while ( 1 ){while ( 1 ){fflush(stdin);fflush(_bss_start);fprintf(_bss_start, "\n%sDragons: [%d/%d]%s\n\n", "\x1B[1;34m", v5, 13LL, "\x1B[1;37m"…

挑战30天学完Python:Day18 正则表达式

&#x1f4d8; Day 18 &#x1f389; 本系列为Python基础学习&#xff0c;原稿来源于 30-Days-Of-Python 英文项目&#xff0c;大奇主要是对其本地化翻译、逐条验证和补充&#xff0c;想通过30天完成正儿八经的系统化实践。此系列适合零基础同学&#xff0c;或仅了解Python一点…

测试开源C#人脸识别模块DlibDotNet

百度“C# 换脸”找到参考文献4&#xff0c;发现其中使用DlibDotNet检测并识别人脸&#xff08;之前主要用的是ViewFaceCore&#xff09;&#xff0c;DlibDotNet是Dlib的.net封装版本&#xff0c;后者为开源C工具包&#xff0c;支持机器学习算法、图像处理等算法以支撑各类高级应…

CVE-2023-44313 Apache ServiceComb Service-Center SSRF 漏洞研究

本次项目基于go语言&#xff08;本人不精通&#xff09;&#xff0c;虽不是java web框架了 &#xff0c;但搭建web服务的框架一些思想理念却是通用的&#xff0c;我们由此可以得到一些蛛丝马迹....... 目录 漏洞简介 漏洞分析 漏洞复现 漏洞简介 Apache ServiceComb Servi…

应用感知型网络性能管理

网络基础设施似乎日益复杂和先进&#xff0c;迫使网络管理员抛弃传统的管理方法。应用感知型网络性能管理是一种用于监控网络性能的新型整体方法&#xff0c;它为管理员提供了强大的 IT 资源管理功能。应用感知型网络性能管理为 IT 管理员带来了精细视图、动态资源分配、主动故…

【计网】TCP的三次握手四次挥手

&#x1f34e;个人博客&#xff1a;个人主页 &#x1f3c6;个人专栏&#xff1a;JAVA ⛳️ 功不唐捐&#xff0c;玉汝于成 目录 前言 正文 三次握手&#xff08;Connection Establishment&#xff09; 四次挥手&#xff08;Connection Termination&#xff09; 结语 我…

Linux之权限管理

目录 一.chmod 二.ACL权限 2.1概述 2.2应用ACL权限 一.chmod chmod命令是控制用户对文件的权限的命令。 只有文件所有者和超级用户可以修改文件或目录的权限。 使用权限 : 所有使用者 语法: chmod [-cfvR] [--help] [--version] mode file... 参数说明&#xff1a; mode : …

前端学习——vue学习

文章目录 1. < el-form> 属性 model、prop、rules2. v-bind 与 v-model3. v-if 与 v-show4. v-for 循环语句5. 计算属性 computed6. 监视属性 watch7. 下拉框 el-select、el-option8. 自定义事件9. async与await实现异步调用 1. < el-form> 属性 model、prop、rule…