【MySQL学习笔记008】多表查询

1、多表关系

        概述:项目开发中,在进行数据库表结构设计时,会根据业务需求及业务模块之间的关系,分析并设计表结构,由于业务之间相互关联,所以各个表结构之间也存在着各种联系,基本上可分为三种:

        一对多(多对一)

        多对多

        一对一

2、多表查询概述

        概述:从多张表中查询数据

        笛卡尔积:笛卡尔乘积是指在数学中,两个集合A集合和B集合的所有组合情况(在多表查询时,需要消除无效的笛卡尔积)

3、多表查询分类

        内连接:对A、B表交集部分的数据进行操作

        外连接:分为左外连接与右外连接。

        左外连接:相当于查询表1(左表)的所有数据 包含 表1和表2交集部分的数据,也就是表1的全部数据

        右外连接:与左外连接同理,也就是表2 的全部数据

这种情况主要用于查询有些未关联的数据

        自连接:当前表与自身的连接查询,自连接必须使用表别名;自连接查询,可以是内连接查询,也可以是外连接查询。

        联合查询:把多次查询的结果合并起来,形成一个新的查询结果集。对于联合查询的多张表的列数必须保持一致,字段类型也需要保持一致。

        子查询:SQL语句中嵌套select语句,称为嵌套查询,又称子查询。

        根据子查询结果不同,分为:

                标量子查询(子查询结果为单个值)

                列子查询(子查询结果为一列,可以为多行)

                行子查询(子查询结果为一行,可以为多列)

                表子查询(子查询结果为多行多列)

        根据子查询位置,分为where之后,from之后,select之后。

4、内连接:相当于查询A、B交集部分数据

        内连接查询语法:

        隐式内连接

                select 字段列表 from 表1, 表2 where 条件...;

        显式内连接

                select 字段列表 from 表1 [inner] join 表2 on 连接条件...;

5、外连接:

        左外连接:查询左表所有数据,以及两张表交集部分数据

                select 字段列表 from 表1 left [outer] join 表2 on 条件...;

        右外连接:查询右表所有数据,以及两张表交集部分数据

                select 字段列表 from 表1 right [outer] join 表2 on 条件...;

6、自连接

        select 字段列表 from 表A 别名A join 表A 别名B on 条件...;

7、联合查询(union, union all)

        select 字段列表 from 表A...

        union [all]

        select 字段列表 from 表B...;

        union all -- 会将全部的数据直接合并在一起,不带去重功能

        union-- 会对合并之后的数据去重,自带去重功能

8、子查询

        select * from t1 where column1-(select column1 from t2);

        子查询外部的语句可以是insert/update/delete/select的任何一个。

        标量子查询:

                返回的结果是单个值(数字、字符串、日期等),最简单的形式,这种子查询称为标量子查询。

        列子查询

                子查询返回的结构是一列(可以是多行),这种子查询称为 列子查询。

        常用的操作符:IN、NOT IN、ANY、SOME、ALL

        行子查询:

        常用的操作符: =、<>、IN、NOT IN

        表子查询:

        常用的操作符: IN

9、多表查询案例

        1. 查询员工的姓名、年龄、职位、部门信息

        2. 查询年龄小于30岁的员工姓名、年龄、职位、部门信息。

        3. 查询拥有员工的部门ID、部门名称。

        4. 查询所有年龄大于40岁的员工,及其归属的部门名称,如果员工没有分配部门,也需要展示出来。

        5. 查询所有员工的工资等级。

        6. 查询“研发部”所有员工的信息及工资等级

        7. 查询“研发部”员工的平均工资

        8. 查询工资比"灭绝”高的员工信息

        9. 查询比平均薪资高的员工信息

        10. 查询低于本部门平均工资的员工信息

        11. 查询所有的部门信息,并统计部门的员工人数。

        12. 查询所有学生的选课情况,展示出学生名称,学号,课程名称

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

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

相关文章

WT2605C高品质音频蓝牙语音芯片:外接功放实现双声道DAC输出的优势

在音频处理领域&#xff0c;双声道DAC输出能够提供更为清晰、逼真的音效&#xff0c;增强用户的听觉体验。针对这一需求&#xff0c;唯创知音的WT2605C高品质音频蓝牙语音芯片&#xff0c;通过外接功放实现双声道DAC输出&#xff0c;展现出独特的应用优势。 一、高品质音频处理…

企业计算机服务器中了babyk勒索病毒怎么办,babyk勒索病毒解密数据恢复

在数字化的今天&#xff0c;网络安全威胁不断增加&#xff0c;给企业的生产生活带来了严重影响&#xff0c;使得企业不得不重视数据安全问题。近日&#xff0c;云天数据恢复中心接到企业求助&#xff0c;企业的计算机服务器中了babyk勒索病毒&#xff0c;导致企业所有计算机系统…

论文降重方法同义词替换的效果对比与评价 快码论文

大家好&#xff0c;今天来聊聊论文降重方法同义词替换的效果对比与评价&#xff0c;希望能给大家提供一点参考。 以下是针对论文重复率高的情况&#xff0c;提供一些修改建议和技巧&#xff0c;可以借助此类工具&#xff1a; 标题&#xff1a;论文降重方法同义词替换的效果对比…

使用travelbook架设自己的实时位置共享服务

travelbook 是一款开源的安卓APP&#xff0c;它能以低功耗提供实时位置共享&#xff0c;它包含功能如下&#xff1a; 好友之间分享实时位置&#xff1b;记录行程轨迹&#xff1b;标记收藏地点&#xff1b; 这款软件的主要解决的问题包括&#xff1a; 场景1&#xff1a;查看老…

Ps:直方图 - 统计数据

使用扩展视图或全部通道视图时&#xff0c;直方图 Histogram的下方会显示一组实时统计数据。 提示&#xff1a; 要在直方图面板控制菜单中勾选&#xff08;默认&#xff09;“显示统计数据” Show Statistics。 源 Source --整个图像 Entire Image 默认选项。显示整个图像&am…

Apache Superset如何实现无公网ip实时远程访问本地数据【内网穿透】

文章目录 前言1. 使用Docker部署Apache Superset1.1 第一步安装docker 、docker compose1.2 克隆superset代码到本地并使用docker compose启动 2. 安装cpolar内网穿透&#xff0c;实现公网访问3. 设置固定连接公网地址 前言 Superset是一款由中国知名科技公司开源的“现代化的…

MySQL的事务-原子性

MySQL的事务处理具有ACID的特性&#xff0c;即原子性&#xff08;Atomicity)、一致性&#xff08;Consistency&#xff09;、隔离性&#xff08;Isolation&#xff09;和持久性&#xff08;Durability&#xff09;。 1. 原子性指的是事务中所有操作都是原子性的&#xff0c;要…

第十四节TypeScript 联合类型

1、简介 联合类型可以通过管道&#xff08;|&#xff09;将变量设置多种类型&#xff0c;赋值时可以根据设置的类型来赋值。 注意&#xff1a;只能赋值指定的类型&#xff0c;如果赋值其它类型就会报错的。 2、创建联合类型的语法格式&#xff1a; Type1|Type2|Type3 实例&a…

收银管理系统怎样帮助商家很好地经营服装门店

收银管理系统对于服装门店的经营可以提供多方面的帮助&#xff0c;以下是一些具体的优势和功能&#xff1a; 1. 快速准确的收银&#xff1a;收银管理系统可以实现快速、准确的收银操作&#xff0c;通过条码扫描或手动输入商品信息&#xff0c;自动计算价格并生成收据。这样可以…

CPP虚析构函数

#include<iostream> using namespace std;class base {public:base(){};virtual ~base(){}; };// 在类声明中声明纯虚析构函数 //base::~base() {}class father: public base {public:~father(){cout << "father" << endl;} };int main() {base* a…

CnosDB:深入了解时序数据处理函数

CnosDB 是一个专注于时序数据处理的数据库&#xff0c;旨在解决时序数据存储与分析问题&#xff0c;为用户提供高效的时序数据管理与查询便利。为了实现这一目标&#xff0c;CnosDB 实现了一系列专用函数&#xff0c;快来和CC一起来看看吧&#xff01; CnosDB&#xff1a;深入了…

机器学习-数学学习汇总

***I数学只是一个工具&#xff0c;会使用&#xff0c;能解决问题就可以了&#xff0c;精确例如到3.14够用就可以了*** 微积分作用&#xff1a;解决非线性问题 学习&#xff1a;27分。 高中数学&#xff1a; 1.高中数学所有知识点表格总结&#xff0c;高中知识点一个不漏&am…