前言
從今天開始本系列文章就帶各位小夥伴學習資料庫技術。資料庫技術是Java開發中必不可少的一部分知識内容。也是非常重要的技術。本系列教程由淺入深, 全面講解資料庫體系。 非常适合零基礎的小夥伴來學習。
全文大約 【1258】字,不說廢話,隻講可以讓你學到技術、明白原理的純幹貨!本文帶有豐富案例及配圖,讓你更好的了解和運用文中的技術概念,并可以給你帶來具有足夠啟迪的思考......
一. 子查詢
什麼是子查詢呢?健哥來為各位小夥伴細細道來。所謂子查詢就是将一個查詢結果作為判斷條件或者作為一張虛拟表在這個結果的基礎上進行另一個查詢。
1.子查詢(作為條件判斷)
下面就是将查詢結果作為另一個查詢的判斷條件。
文法 : SELECT 列名 FROM 表名 Where 條件 (子查詢結果)
舉個例子:查詢和健哥同歲的其他同學。
#1.先查詢到健哥的年齡
select Sage from student where Sname='健哥'; #年齡是12
#2.查詢年齡等于健哥年齡的同學
select * from student where Sage=12;
#3.将 1、2 兩條語句整合
select * from student where Sage=(select Sage from student where Sname='健哥');
複制代碼
注意 : 将子查詢 ”一行一列“的結果作為外部查詢的條件,做第二次查詢子查詢得到一行一列的結果才能作為外部查詢的等值判斷條件或不等值條件判斷。
2.子查詢(作為枚舉查詢條件)
子查詢作為枚舉查詢條件使用是将一個查詢結果(單列多行)的結果集作為枚舉查詢條件進行二次查詢。
文法 :SELECT 列名 FROM 表名 Where 列名 in(子查詢結果);
舉個栗子:查詢和健哥,旭哥同齡的學生資訊。
#思路:
#1. 先查詢健哥和旭哥的年齡(多行單列)
select Sage from student where Sname in('健哥', '旭哥'); #年齡是12和23
#2. 再查詢年齡為12和23的學員資訊
select * from student where Sage in(12, 23);
#3.SQL:合并
select * from student where Sage in(select Sage from student where Sname in('健哥', '旭哥'));
複制代碼
将子查詢 ”多行一列“的結果作為外部查詢的枚舉查詢條件,做第二次查詢。
3.子查詢(作為一張表)
此處健哥敲黑闆啦!非常重要,使用頻率很高!
下面的子查詢是将一個查詢的結果當做一張虛拟表,然後在這個表的結果基礎上再進行查詢。
文法 :SELECT 列名 FROM (子查詢的結果集) WHERE 條件;
舉個栗子:查詢最老的5名學生資訊。
#思路:
#1. 先對學生年齡排序查詢(排序後的臨時表)
select * from student order by Sage desc;
#2. 再查詢臨時表中前5行學生資訊
select *
from (臨時表)
limit 0,5;
#SQL:合并
select * from (
select * from student order by Sage desc
) as temp limit 0,4;
複制代碼
将子查詢 ”多行多列“的結果作為外部查詢的一張表,做第二次查詢。
注意: 子查詢作為臨時表,為其賦予一個臨時表名。
二. 結語
最後在這裡對本文核心要點進行總結:
1. 子查詢有三種使用場景分别是:子查詢結果作為判斷條件、子查詢結果作為枚舉條件、子查詢結果作為一個虛拟表進行二次查詢。
2. 以上三種使用方式各位小夥伴要熟練掌握哦。
更多計算機程式設計、IT技術、技術類知識點,關注@千鋒教育