子查询在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.EmployeeWHERE DepartmentID = (SELECT DepartmentIDFROM test.DepartmentWHERE 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 EmployeeWHERE DepartmentID = (SELECT DepartmentIDFROM DepartmentsWHERE 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 AvgDepartmentSalaryFROM (# 计算每个部门平均工资SELECT DepartmentID, AVG(Salary) AS AvgDepartmentSalaryFROM test.EmployeeGROUP BY DepartmentID) AS DepartmentAvgWHERE e.DepartmentID = DepartmentAvg.DepartmentID
);

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

结语

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

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

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

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

相关文章

Android Studio Giraffe-2022.3.1-Patch-3安装注意事项

准备工作: android studio下载地址:https://developer.android.google.cn/studio/releases?hlzh-cn gradle下载地址:https://services.gradle.org/distributions/ 比较稳定的网络环境(比较android studio相关的依赖需要从谷歌那边…

背包问题学习

背包问题是常见的动态规划dp的问题 下面用到的符号: 常用n表示物品数, m表示背包容积f[i][j]表示i件物品, j的背包容量的最大价值w[i]表示第i件物品的价值, v[i] 表示第i件物品的容量f[0][0~m] 0, 所以n可以从1开始遍历一般是有两层嵌套循环 第一层遍历物品, 第二层遍历背包…

无线4G电表和有线智能电表哪个通讯更稳定?

当谈论智能电表的通讯方式时,常常会提到无线4G电表和有线智能电表两种选择。那么,这两款电表哪个通讯更稳定呢?下面,我们就一起来看下吧! 首先,我们来看无线4G电表的通讯方式。无线4G电表通过无线网络进行通…

日志收集 grafana-loki

文章目录 部署 grafana-loki部署 grafana配置 loki 源配置节点大盘 部署 grafana-loki 官方文档:部署 grafana-loki 部署命令 设置集群的存储类,如果有默认可以不设置设置命名空间 helm install loki oci://registry-1.docker.io/bitnamicharts/grafa…

Android 缩减、混淆处理和优化应用

为了尽可能减小应用的大小,您应在发布 build 中启用缩减功能来移除不使用的代码和资源。启用缩减功能后,您还会受益于两项功能,一项是混淆处理功能,该功能会缩短应用的类和成员的名称;另一项是优化功能,该功…

学生档案管理系统设计

摘要 随着科学技术的不断提高,计算机科学日渐成熟,其强大的功能已为人们深刻认识,它已进入人类社会的各个领域并发挥着越来越重要的作用。作为计算机应用的一部分,使用计算机对学生档案信息进行管理,具有着手工管理所无法比拟的优点.例如:检索迅速、查找方便、可靠性高、存储量…

Vue3-数据交互请求工具设计

1.安装axios pnpm add axios 2.利用axios.create创建一个自定义的axios来使用 参考官网:axios中文文档|axios中文网 | axios 在src/utils文件夹下新建request.js,封装axios模块 import axios from axios const baseURL const instance axios.creat…

你真的掌握结构体了么?结构体习题(C语言)

前言 上一期博客我们学习了结构体的相关知识(上期链接),但是学了不练也是不行的,我们今天讲给大家分享两道有点恶心的题目,让大家来加深对结构体的理解,那么话不多说我们现在开始吧! 第一题 有…

2023年最详细介绍Linux 系统目录结构!你确定不来了解一下吗?

📚📚 🏅我是默,一个在CSDN分享笔记的博主。📚📚 ​​​ 🌟在这里,我要推荐给大家我的专栏《Linux》。🎯🎯 🚀无论你是编程小白,还是有…

网络和Linux网络_11(数据链路层)以太网(MAC帧)协议+局域网转发+ARP协议

目录 1. 以太网协议 1.1 MAC地址 1.2 以太网帧格式 2. 局域网转发原理 2.1 数据碰撞和交换机 2.2 最大传输单元MTU 3. ARP协议 3.1 ARP协议格式 3.2 模拟APR协议工作过程 3.3 ARP缓存表 4. 重看TCP/IP四层模型 本篇完。 1. 以太网(MAC帧)协议 网络层的IP协议并不是…

Linux基础命令(测试相关)

软件测试相关linux基础命令笔记 操作系统 常见Linux: Redhat系列:RHSL、Centos、FedoraDebian系列:Debian、Ubuntu以上操作系统都是在原生Linux系统上,增加了一些软件或功能。linux的文件及路径特点 Linux没有盘符的概念&#xf…

PAD平板签约投屏软件要如何选

又是一年年底了,年会开始多起来了,许多会务公司或活动公司会接到很多平板签约投屏业务,如年会中的签军令状、业绩保证书等。这时就面临选购一套签约投屏软件了。 目前的签约投屏软件,大多以H5做的网页版的多,但我建议…

ModbusRTU\TCP消息帧解析(C#实现报文发送与解析)

目录 知识点常用链接一、Modbus1.ModbusRTU消息帧解析2.主站poll、从站slave通讯仿真-modbusRTU1.功能码01读线圈状态2.功能码03读保持寄存器报文解析(寄存器存整型)报文解析(寄存器存float) 3.C#模拟主站Poll(ModbusR…

Redis 入门、基础。(五种基本类型使用场景)

文章目录 1. 概况1.1 认识 NoSQL1.1.1 查询方式1.1.2 事务1.1.3 总结 2. 认识 Redis4. Redis 常见命令4.1 Redis 数据结构介绍4.2 Redis 通用命令4.3 Redis 命令之 String 命令4.4 Redis 命令的层级结构4.5 Redis 命令之 Hash 命令4.6 Redis 命令之 List 命令4.7 set 唯一不排序…

DOM 事件的注册和移除

前端面试大全DOM 事件的注册和移除 🌟经典真题 🌟DOM 注册事件 HTML 元素中注册事件 DOM0 级方式注册事件 DOM2 级方式注册事件 🌟DOM 移除事件 🌟真题解答 🌟总结 🌟经典真题 总结一下 DOM 中如何…

Linux简单部署Yearning并结合内网穿透工具发布至公网可访问

目录 前言 1. Linux 部署Yearning 2. 本地访问Yearning 3. Linux 安装cpolar 4. 配置Yearning公网访问地址 5. 公网远程访问Yearning管理界面 6. 固定Yearning公网地址 前言 Yearning 简单, 高效的MYSQL 审计平台 一款MYSQL SQL语句/查询审计工具,为DBA与开发…

深度学习之图像分类(十五)DINAT: Dilated Neighborhood Attention Transformer详解(一)

Dilated Neighborhood Attention Transformer Abstract Transformers 迅速成为跨模态、领域和任务中应用最广泛的深度学习架构之一。在视觉领域,除了对普通Transformer的持续努力外,分层Transformer也因其性能和易于集成到现有框架中而受到重视。这些模…

Domino多Web站点托管

大家好,才是真的好。 看到一篇文档,大概讲述的是他在家里架了一台Domino服务器,上面跑了好几个Internet的Web网站(使用Internet站点)。再租了一台云服务器,上面安装Nginx做了反向代理,代理访问…

GPTS-生成一个动漫图像GPT

介绍 GPTs是ChatGPT的定制版本,用户可以通过组合指令、知识和功能来定制用于特定任务或主题的GPT。它们可以根据需要简单或复杂,解决从语言学习到技术支持等各种事情。 创建GPTs Plus和Enterprise用户可以在chat.openai.com/create上开始创建GPTs。 您可以通过在ChatGPT上的…

【头歌系统数据库实验】实验4 MySQL单表查询

目录 第1关. 在users表中新增一个用户,user_id为2019100904学号,name为2019-物联网-李明 第2关. 在users表中更新用户 user_id为robot_2 的信息,name设为 机器人二号 第3关. 将solution表中所有 problem_id 为1003 题目的解答结果&#xf…