子查询在SQL中的应用和实践

作者:CSDN-川川菜鸟

在SQL中,子查询是一种强大的工具,用于解决复杂的数据查询问题。本文将深入探讨子查询的概念、类型、规则,并通过具体案例展示其在实际应用中的用途。

文章目录

    • 子查询概念
    • 子查询的类型
    • 子查询的规则
    • 实际案例分析
      • 员工部门数据查询
      • 子查询初阶
      • 子查询进阶应用
    • 结语

子查询概念

子查询,即嵌套查询,是在另一个查询内部执行的查询。它可以用于SELECT、INSERT、UPDATE和DELETE语句中,以及在WHERE和HAVING子句中。子查询通常用于执行比较操作和返回特定的值集。

子查询的类型

子查询可分为几种类型,根据返回的数据量和与外部查询的关系来区分:

  • 单行子查询:返回单个行的值。
  • 多行子查询:返回多行结果,适用于IN或ANY等操作符。
  • 关联子查询:引用外部查询的列,与外部查询有直接联系。

子查询的规则

  • 子查询必须用括号括起来。
  • 子查询可以有自己的 WHERE 子句。
  • 在 SELECT 子句中的子查询应该只返回一个字段。

实际案例分析

员工部门数据查询

假设我们有两个表:Employees和Departments,分别存储员工信息和部门信息。以下是创建这两个表的SQL命令及插入数据的示例:

Departments 表 - 存储部门信息。

CREATE TABLE `Departments` (
CREATE TABLE test.Department (
    DepartmentID INT PRIMARY KEY,
    DepartmentName VARCHAR(50)
);

Employee 表 - 存储员工信息,包括他们所属的部门。

CREATE TABLE test.Employee (
    EmployeeID INT PRIMARY KEY,
    Name VARCHAR(50),
    Salary DECIMAL(10, 2),
    DepartmentID INT,
    FOREIGN KEY (DepartmentID) REFERENCES Department(DepartmentID)
);

插入数据到部门表:

INSERT INTO test.Department (DepartmentID, DepartmentName) VALUES (1, 'Finance');
INSERT INTO test.Department (DepartmentID, DepartmentName) VALUES (2, 'HR');
INSERT INTO test.Department (DepartmentID, DepartmentName) VALUES (3, 'IT');

如下所示:
在这里插入图片描述

员工数据:

INSERT INTO test.Employee (EmployeeID, Name, Salary, DepartmentID) VALUES (1, 'Alice', 70000, 1);
INSERT INTO test.Employee (EmployeeID, Name, Salary, DepartmentID) VALUES (2, 'Bob', 48000, 2);
INSERT INTO test.Employee (EmployeeID, Name, Salary, DepartmentID) VALUES (3, 'Charlie', 50000, 1);
INSERT INTO test.Employee (EmployeeID, Name, Salary, DepartmentID) VALUES (4, 'David', 55000, 3);
INSERT INTO test.Employee (EmployeeID, Name, Salary, DepartmentID) VALUES (5, 'Eve', 75000, 1);

如下所示:
在这里插入图片描述

子查询初阶

我们希望找到薪水高于财务部门平均薪水的员工。

SELECT Name, Salary
FROM test.Employee
WHERE Salary > (
    SELECT AVG(Salary)
    FROM test.Employee
    WHERE DepartmentID = (
        SELECT DepartmentID
        FROM test.Department
        WHERE DepartmentName = 'Finance'
    )
);
  • 外部查询:最外层查询找出所有薪水高于财务部门平均薪水的员工
  • 中间子查询:SELECT AVG(Salary) FROM Employees WHERE DepartmentID = (…) 使用内部子查询的结果来计算财务部门的平均薪水。
  • 内部子查询:SELECT DepartmentID FROM Departments WHERE DepartmentName = ‘Finance’ 查找财务部门的 ID。

分步骤实现解析如下:
1.首先查询财务部门的ID:

SELECT DepartmentID FROM Departments WHERE DepartmentName = 'Finance';

2.计算财务部门的平均薪水:

SELECT AVG(Salary) FROM Employee WHERE DepartmentID = [上一步的结果];

3.最终查询薪水高于财务部门平均薪水的员工:

SELECT Name, Salary FROM Employee WHERE Salary > [第二步的平均薪水];

这三个步骤可以合并为一个子查询:

SELECT Name, Salary
FROM Employee
WHERE Salary > (
    SELECT AVG(Salary)
    FROM Employee
    WHERE DepartmentID = (
        SELECT DepartmentID
        FROM Departments
        WHERE DepartmentName = 'Finance'
    )
);

子查询进阶应用

假设我们现在想要找出在其部门中薪水高于该部门平均薪水的员工,同时这些员工的薪水还要高于公司整体的平均薪水。

1.计算公司整体的平均薪水:

SELECT AVG(Salary) FROM test.Employee;

2.为每个部门计算平均薪水

SELECT DepartmentID, AVG(Salary) AS AvgDepartmentSalary
FROM test.Employee
GROUP BY DepartmentID

3.结合上述两个查询,找出满足条件的员工:

SELECT e.Name, e.Salary, e.DepartmentID
FROM test.Employee e
WHERE e.Salary > (
    SELECT AVG(Salary) FROM test.Employee # 大于公司平均工资
) AND e.Salary > (
    SELECT AvgDepartmentSalary
    FROM (
        # 计算每个部门平均工资
        SELECT DepartmentID, AVG(Salary) AS AvgDepartmentSalary
        FROM test.Employee
        GROUP BY DepartmentID
    ) AS DepartmentAvg
    WHERE e.DepartmentID = DepartmentAvg.DepartmentID
);

通过这些案例,我们可以看到子查询在处理复杂SQL查询中的强大功能和灵活性。掌握子查询的使用可以大大提高数据库查询的效率和效果。

结语

子查询是SQL中一项强大而灵活的功能,能够解决各种复杂的数据查询需求。通过对子查询的深入理解和应用,我们可以在数据库操作中实现更加精细和高效的数据处理。无论是简单的单行子查询还是复杂的关联子查询,它们都是数据库查询语言的重要组成部分,有助于提高我们在数据分析和管理方面的能力。

实际案例的探讨展示了子查询在实际应用中的强大作用,从基础的单表查询到更高级的多表联合查询。这不仅增强了我们对SQL的理解,而且提供了一种思维方式,帮助我们在面对复杂数据挑战时找到高效解决方案。

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

leetcode 1658. 将 x 减到 0 的最小操作数(优质解法)

代码&#xff1a; class Solution {public int minOperations(int[] nums, int x) {int sum0; // nums 数组中的数据总和int lengthnums.length;for(int i0;i<length;i){sumnums[i];}int targetsum-x; //待查找的子数组的和if(target<0){return -1;}//采用滑动窗口的…

团建策划信息展示服务预约小程序效果如何

团建是中大型企业商家每年举办的员工活动&#xff0c;其形式多样化、具备全部参与的娱乐性。但在实际策划流程及内容时&#xff0c;部分公司便会难以入手&#xff0c;术业有专攻&#xff0c;这个时候团建策划公司便会发挥效果。 如拓展训练、露营、运动会、体育竞技等往往更具…

美格智能亮相中国企业家博鳌论坛:勇立创新潮头,5G+AIoT开启智能新时代

12月2日-5日&#xff0c;由新华社和海南省人民政府、中国品牌建设促进会等联合主办的2023中国企业家博鳌论坛在海南博鳌召开&#xff0c;包括众多世界500强、中国500强和行业领军企业家在内的3500多名社会各界嘉宾汇聚一堂&#xff0c;共谋中国经济高质量发展之道。 会议现场 …

知虾网:帮助卖家优化Shopee店铺运营的数据分析工具

在如今的电商时代&#xff0c;越来越多的卖家选择在Shopee平台上开设店铺。然而&#xff0c;随着竞争的加剧&#xff0c;如何提高店铺的曝光率和销售效果成为了卖家们面临的重要问题。为了帮助Shopee卖家更好地了解市场动态、优化商品策略、提高运营效果&#xff0c;知虾网应运…

LeetCode 每日一题 Day 4

2477. 到达首都的最少油耗 给你一棵 n 个节点的树&#xff08;一个无向、连通、无环图&#xff09;&#xff0c;每个节点表示一个城市&#xff0c;编号从 0 到 n - 1 &#xff0c;且恰好有 n - 1 条路。0 是首都。给你一个二维整数数组 roads &#xff0c;其中 roads[i] [ai,…

二叉树OJ题之三

哈喽伙伴们&#xff0c;有一段时间没更新博客了&#xff0c;主要是这段时间要准备学校的期末考试&#xff0c;所以没有把部分时间分给博客&#xff0c;今天我们一起去接着看二叉树递归有关的OJ题&#xff0c;今天我们要学习的是 判断相同的树&#xff0c;力扣题目--100 &…

2023年度亚太客户中心产业发展论坛——鸿联九五荣获亚太区卓越客服大赛客户运营管理类铂金大奖

11月27-28日&#xff0c; 2023年度亚太客户中心产业发展论坛暨亚太区卓越客服大赛在马来西亚吉隆坡举行。来自中国、澳大利亚、马来西亚、新加坡、中国香港、印度尼西亚和泰国等多个国家及地区的优秀企业代表齐聚吉隆坡。 论坛首日活动以“Experience Excellence, Meet the Cha…

Redis应用-缓存

目录 什么是缓存 使用redis作为缓存 缓存的更新策略 通用的淘汰策略 redis内置的淘汰策略 缓存预热 缓存穿透 缓存雪崩 缓存击穿 什么是缓存 缓存(cache)是计算机中一个经典的概念,在很多的场景中都会涉及到. 核心思路就是把一些常用的数据放到触手可及(访问速度更快…

javascript实现List列表数据结构

书籍推荐 有幸拜读《数据结构与算法Javascript描述》这本书&#xff0c;先强烈安利一波&#xff01;非常感谢作者大大给我们前端领域带来这本书。 全书从javascript的角度出发&#xff0c;简单明了的分析了数据结构在javascript领域的实现过程与实际的应用案例&#xff0c;且…

VA03 凭证流 查看备忘

今天被问到了&#xff0c;为什么这个销售订单 只显示了3 EA 仔细看了一下&#xff0c;前面10 是行项目 看销售订单 最后发现&#xff0c;凭证流跟选择查看的行项目有关系 以前一直没有关注这个细节

QT-在ui界面中给QWidget增加Layout布局的两种方法

QT-在ui界面中给QWidget增加Layout布局的两种方法 方式一 在UI界面&#xff0c;用拖拽的方式加入Layout方式二 用notepad软件打开.ui文件&#xff0c;手动加入Layout代码 目标&#xff1a;去除右下角红标&#xff0c;给tab标签增加Layout属性。 方式一 在UI界面&#xff0c;用…

nodejs+vue+ElementUi小区社区公寓宿舍智能访客预约系统

该系统将采用B/S结构模式&#xff0c;前端部分主要使用html、css、JavaScript等技术&#xff0c;使用Vue和ElementUI框架搭建前端页面&#xff0c;后端部分将使用Nodejs来搭建服务器&#xff0c;并使用MySQL建立后台数据系统&#xff0c;通过axios完成前后端的交互&#xff0c;…

生殖感染对生育的影响有哪些?劲松中西医结合医院专家详细解读

生殖感染是指由细菌、病毒、支原体、衣原体等病原微生物引起的生殖道感染&#xff0c;包括前列腺炎、尿道炎、宫颈炎、盆腔炎等。生殖感染对生育的影响是多方面的&#xff0c;今天劲松中西医结合医院谭巍主任将详细介绍这些影响及相应的预防办法。 一、影响生育能力的因素 1.…

❀My学习Linux命令小记录(14)❀

目录 ❀My学习Linux命令小记录&#xff08;14&#xff09;❀ 56.man指令 57.whatis指令 58.info指令 59.--help指令 60.uname指令 ❀My学习Linux命令小记录&#xff08;14&#xff09;❀ 56.man指令 功能说明&#xff1a;查看Linux中的指令帮助。 &#xff08;ps.man命…

软件工程之需求分析

一、对需求的基本认识 1.需求分析简介 (1)什么是需求 用户需求&#xff1a;由用户提出。原始的用户需求通常是不能直接做成产品的&#xff0c;需要对其进行分析提炼&#xff0c;最终形成产品需求。 产品需求&#xff1a;产品经理针对用户需求提出的解决方案。 (2)为什么要…

电力仪表在工厂车间设备电能管理系统的设计-安科瑞黄安南

摘 要&#xff1a;基于车间用电设备的电能管理系统架构思路及实施方法&#xff0c;从硬件和软件方面对此方法进行了阐述。对车间旧设备改造以及新的电能管理系统提供一种思路和便捷的方法。 关键词&#xff1a;电能管理系统&#xff1b;多功能电力仪表&#xff1b;PLC&#x…

菜鸟驿站寄快递真的能省钱吗?还不如去闪侠惠递快递折扣平台下单!

小伙伴们&#xff0c;你们知道我们平常去寄快递发快递的菜鸟驿站是怎么来的吗&#xff1f;今天小编就来带你一探究竟。 那么到菜鸟驿站寄快递真的能省钱吗&#xff1f;其实也不一定。在菜鸟驿站&#xff0c;工作人员称重之后&#xff0c;工作人员说多少就是多少&#xff0c;没…

测试岗外包干了3个月,技术退步明显。。。。。

先说一下自己的情况&#xff0c;本科生生&#xff0c;21年通过校招进入成都某软件公司&#xff0c;干了接近2年的功能测试&#xff0c;今年年初&#xff0c;感觉自己不能够在这样下去了&#xff0c;长时间呆在一个舒适的环境会让一个人堕落!而我已经在一个企业干了2年的功能测试…

微型5G网关如何满足智能巡检机器人应用

在规模庞大、设施复杂的炼化厂、钢铁厂、工业园区等大型、巨型区域&#xff0c;时刻需要对各类设施设备巡查监测&#xff0c;保障生产运行安全可控。传统的人工巡检存在着心态松懈、工作低效、工作强度高、工作环境恶劣等问题&#xff0c;仍然存在安全隐患。 而随着物联网、5G、…

UVM建造测试用例

&#xff08;1&#xff09;加入base_test 在一个实际应用的UVM验证平台中&#xff0c;my_env并不是树根&#xff0c;通常来说&#xff0c;树根是一个基于uvm_test派生的类。真正的测试用例都是基于base_test派生的一个类。 class base_test extends uvm_test;my_env e…