MySQL的子查詢

一、前言

  • MySQL 子查詢是指嵌套在其他 SQL 語句(如 SELECT、WHERE、FROM 等)內部的查詢。
  • 用于輔助主查詢完成復雜的數據篩選或計算。

二、子查詢分類

  • 標量子查詢
    • 描述:返回 單行單列(一個值),常用于比較運算(如 =、>、< 等)。
    • 示例:SELECT name FROM employee WHERE salary (SELECT AVG(salary) FROM employee);
  • 列子查詢
    • 描述:返回 多行單列,需搭配 IN、ANY、ALL 等操作符。
    • 示例: SELECT name FROM department WHERE id IN (SELECT dept_id FROM employee);
  • 行子查詢
    • 描述:返回 單行多列,需用行表達式(如 (col1, col2))匹配。
    • 示例: SELECT FROM employee WHERE (age, salary) = (SELECT MAX(age), MAX(salary) FROM employee);
  • 表子查詢
    • 描述:返回 多行多列,通常作為臨時表(派生表)在 FROM 子句中使用。
    • 示例: SELECT deptname, empcount FROM (SELECT deptid, COUNT(*) AS empcount FROM employee GROUP BY dept_id) AS tmp;
  • 相關子查詢
    • 描述:子查詢依賴外部查詢的字段值,逐行執行(效率較低)。
    • 示例: SELECT name FROM employee e1 WHERE salary (SELECT AVG(salary) FROM employee e2 WHERE e1.deptid = e2.deptid);

三、常用操作符

  • IN / NOT IN:用于判斷值是否在子查詢的結果集中
-- 查詢有訂單的客戶
SELECT customer_name 
FROM customers 
WHERE id IN (SELECT customer_id FROM orders);
  • ANY / SOME:比較值與子查詢結果中的任意一個是否滿足條件
-查詢薪資大于任意一個部門平均薪資的員工 
SELECT name  FROM employee  WHERE salary ANY (SELECT AVG(salary) FROM employee GROUP BY dept_id);
  • ALL:比較值需滿足與子查詢結果中的所有值
-查詢薪資高于所有部門平均薪資的員工 
SELECT name  FROM employee  WHERE salary ALL (SELECT AVG(salary) FROM employee GROUP BY dept_id);
  • XISTS / NOT EXISTS:檢查子查詢是否返回至少一行結果
-- 查詢有下屬部門的上級部門
SELECT dept_name 
FROM departments d 
WHERE EXISTS (SELECT 1 FROM departments WHERE parent_id = d.id);

四、典型應用場景

  • 1、在 WHERE 子句中篩選數據
-- 查找薪資高于平均值的員工
SELECT name, salary 
FROM employee 
WHERE salary > (SELECT AVG(salary) FROM employee);
  • 2、在 FROM 子句中作為臨時表
-- 統計每個部門的平均薪資,并篩選高于公司平均薪資的部門
SELECT dept_id, avg_salary
FROM (SELECT dept_id, AVG(salary) AS avg_salary FROM employee GROUP BY dept_id) AS dept_avg
WHERE avg_salary > (SELECT AVG(salary) FROM employee);
  • 3、在 FROM 子句中作為臨時表
-- 顯示員工姓名及其部門平均薪資
SELECT name, salary, (SELECT AVG(salary) FROM employee e2 WHERE e1.dept_id = e2.dept_id) AS dept_avg
FROM employee e1;

五、注意事項

  • 性能優化:相關子查詢需逐行執行,可能影響性能,可嘗試改寫為 JOIN 或臨時表。
  • 處理 NULL 值:使用 IN 或 NOT IN 時,若子查詢結果包含 NULL,可能導致意外結果(如 NOT IN (NULL, …) 永遠返回 FALSE)。
  • 多層嵌套:MySQL 支持多層子查詢嵌套,但需保持代碼可讀性。
  • 別名使用:派生表必須指定別名(如 FROM (SELECT …) AS tmp)。

六、示例:復雜查詢

-- 查找每個部門薪資最高的員工
SELECT dept_id, name, salary
FROM employee e1
WHERE salary = (SELECT MAX(salary) FROM employee e2 WHERE e1.dept_id = e2.dept_id
);
  • 通過靈活運用子查詢,可以解決大部分復雜的數據關聯和篩選需求。
  • 實際開發中需結合執行計劃分析,確保查詢效率。

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/web/75114.shtml
繁體地址,請注明出處:http://hk.pswp.cn/web/75114.shtml
英文地址,請注明出處:http://en.pswp.cn/web/75114.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

Linux 基礎入門操作 前言 VIM的基本操作 2

1 VIM的背景介紹 Vi 的誕生與1976年&#xff0c;Vim 的前身是 Vi&#xff08;Visual Editor&#xff09;&#xff0c;由 Bill Joy 在 BSD Unix 系統上開發&#xff0c;作為 ed&#xff08;行編輯器&#xff09;的改進版本&#xff0c;提供全屏編輯功能&#xff0c;成為 Unix/L…

Java:Set操作

目錄 Set 轉 List Set 轉 List Set<String>set new HashSet<String>(); set.add("c"); set.add("d"); set.add("a"); set.add("a");//方法一&#xff1a; List<String>list new ArrayList<String>(set);//…

算力驅動未來:從邊緣計算到高階AI的算力革命

算力驅動未來&#xff1a;從邊緣計算到高階AI的算力革命 摘要 本文深入探討了不同算力水平&#xff08;20TOPS至160TOPS&#xff09;在人工智能領域的多樣化應用場景。從邊緣計算的實時目標檢測到自動駕駛的多傳感器融合&#xff0c;從自然語言處理的大模型應用到AI for Scie…

虛擬機上安裝openEuler和openGauss數據庫

1.虛擬機版本選擇VM 16 PRO 2.openEuler版本選擇openEuler-22.03-LTS-SP4-x86_64 下載地址&#xff1a;https://mirrors.aliyun.com/openeuler/openEuler-22.03-LTS-SP4/ISO/x86_64/openEuler-22.03-LTS-SP4-x86_64-dvd.iso 3.虛擬機安裝openEuler過程&#xff1a; 4.安裝ope…

0_Pytorch中的張量操作

[引言]張量的概念 1.基本概念 張量是一個通用的多維數組&#xff0c;可以表示標量&#xff08;0 維&#xff09;、向量&#xff08;1 維&#xff09;、矩陣&#xff08;2 維&#xff09;以及更高維度的數據。張量是 PyTorch 中的核心數據結構&#xff0c;用于表示和操作數據。…

LS-LINUX-002 簡易創建SSH

LS-LINUX-002 簡易創建SSH 1. CentOS 8 創建和配置SSH服務 1.1 安裝SSH服務 CentOS 8 默認已經安裝了OpenSSH服務。如果沒有安裝&#xff0c;可以使用以下命令安裝&#xff1a; sudo dnf install -y openssh-server1.2 啟動SSH服務 安裝完成后&#xff0c;需要啟動SSH服務…

計算機專業求職面試的常見題目分類整理

以下是計算機專業求職面試的常見題目分類整理&#xff0c;每個大類精選20道高頻問題&#xff0c;結合參考內容進行解析與擴展&#xff0c;幫助系統化備考&#xff1a; 一、數據結構與算法 解釋時間復雜度和空間復雜度 時間復雜度衡量算法執行時間隨輸入規模的增長趨勢&#xf…

腳本啟動 Java 程序

如果你想在后臺啟動一個 Java 程序&#xff0c;并在終端窗口中顯示一個自定義的名字&#xff0c;可以通過編寫一個簡單的腳本來實現。以下是一個基于 Linux/macOS 的解決方案&#xff0c;使用 Bash 腳本啟動 Java 程序&#xff0c;并在終端窗口中顯示自定義標題。 示例腳本 創建…

CentOS禁用nouveau驅動

1、驗證 nouveau 是否在運行 lsmod | grep nouveau如果命令返回結果&#xff0c;說明 nouveau 驅動正在運行。 2、編輯黑名單文件 通過編輯黑名單配置文件來禁用 nouveau 驅動&#xff0c;這樣在系統啟動時不會加載它。 vi /etc/modprobe.d/blacklist-nouveau.conf修改以下…

Linux: network: tcpdump: packets dropped by kernel

文章目錄 最近遇到一個問題原因libpcap/tcpdump 接口linux/libpcap 接口內核的處理原因可能有以下幾種:解決方法:man pcap_stats最近遇到一個問題 tcpdump命令顯示有dropped的包,而且是被內核drop的。 [root@-one-01 ~]# tcpdump -i any udp and port 8080 -v -w /root/udp…

WEB安全--提權思路

一、情形 在我們成功上傳webshell到服務器中并拿到權限時&#xff0c;發現我們的權限很低無法執行特定的命令&#xff0c;這時為了能做更多的操作&#xff0c;我們就需要提升權限。 二、方式 2.1、Windows提權 1、普通用戶執行systeminfo命令獲取服務器的基本信息&#xff0…

001 vue

https://cn.vuejs.org/ 文章目錄 v-bindv-modelv-on修飾符條件渲染/控制&#xff1a;v-if v-show列表渲染 M&#xff1a;即Model&#xff0c;模型&#xff0c;包括數據和一些基本操作 V&#xff1a;即View&#xff0c;視圖&#xff0c;頁面渲染結果 VM&#xff1a;即View-Mode…

Tomcat 負載均衡

目錄 二、Tomcat Web Server 2.1 Tomcat 部署 2.1.1 Tomcat 介紹 2.1.2 Tomcat 安裝 2.2 Tomcat 服務管理 2.2.1 Tomcat 啟停 2.2.2 目錄說明 2.2.3編輯主頁 2.3 Tomcat管理控制臺 2.3.1開啟遠程管理 2.3.2 配置遠程管理密碼 三、負載均衡 3.1 重新編譯Nginx 3.1.1 確…

使用SpringSecurity下,發生重定向異常

使用SpringSecurity下&#xff0c;發生空轉異常 環境信息&#xff1a; Spring Boot 3.4.4 &#xff0c; jdk 17 &#xff0c; springSecurity 6.4.4 問題背景&#xff1a; 沒有自定義controller &#xff0c;改寫了login 頁面&#xff0c;并且進行了成功后的跳轉處理&#xf…

S130N-ISI 全棧方案與云平臺深度協同:重構 PLC 開發新范式

一、什么是 PLC&#xff1f; 1.技術定義 PLC&#xff08;Power Line Communication&#xff09;是一種創新的通信技術&#xff0c;它以電力線作為天然的傳輸介質&#xff0c;通過先進的信號調制技術將高頻數據信號疊加于工頻電流之上&#xff0c;實現電力輸送與數據通信的雙頻共…

SU-YOLO:基于脈沖神經網絡的高效水下目標檢測模型解析

論文地址:https://arxiv.org/pdf/2503.24389 目錄 一、論文概述 二、創新點解析 1. 基于脈沖的水下圖像去噪(SpikeDenoiser) 原理與結構 2. 分離批歸一化(SeBN) 原理與結構 3. 優化的殘差塊(SU-Block) 原理與結構 三、代碼復現指南 環境配置 模型訓練 四、…

實現阿里云服務器上的文字聊天程序以及C語言寫的進程間通信(IPC)程序

實現阿里云服務器上的文字聊天程序以及C語言寫的進程間通信&#xff08;IPC&#xff09;程序 1. 基于 Linux 中的管道進行進程間通信 我們首先使用管道進行進程間通信&#xff0c;這對于簡單的聊天程序來說是一個比較簡單且實用的方法。 步驟&#xff1a; 創建管道&#xf…

COMSOL 與人工智能融合的多物理場應用:28個案例的思路、方法與工具概述

應用案例概述 基于 COMSOL 與人工智能&#xff08;AI&#xff09;結合的應用案例涵蓋了 28 個多領域場景&#xff0c;包括工程&#xff08;如熱傳導優化、結構力學預測&#xff09;、能源&#xff08;如電池熱管理、燃料電池性能&#xff09;、生物醫學&#xff08;如藥物傳遞…

SAN及其ZONE

目錄 一、什么是SAN? 二、什么是ZONE? 三、配置ZONE 2.1 核心概念 2.2 劃分原則 2.3 Zone劃分最佳實踐 2.4 配置語法 1). 基于端口&#xff08;Domain,Port&#xff09;的zone語法 2). 基于WWN&#xff08;World Wide Name&#xff09;的Zone語法 3). 使用Alias簡化配置 4).…

Springboot框架—單元測試操作

Springboot單元測試的操作步驟&#xff1a; 1.添加依賴spring-boot-starter-test 在pom.xml中添加依賴spring-boot-starter-test 2.在src/test/java下新建java class 3.單元測試入口代碼結構 import org.junit.Test; import org.junit.runner.RunWith; import org.springfra…