MySQL子查詢的使用詳解上篇
前言
子查詢指一個查詢語句嵌套在另一個查詢語句內部的查詢,這個特性從MySQL 4.1開始引入。
SQL 中子查詢的使用大大增強了 SELECT 查詢的能力,因為很多時候查詢需要從結果集中獲取數(shù)據(jù),或者 需要從同一個表中先計算得出一個數(shù)據(jù)結果,然后與這個數(shù)據(jù)結果(可能是某個標量,也可能是某個集 合)進行比較。
需求分析與問題解決

#方式一: SELECT salary FROM employees WHERE last_name = 'Abel'; SELECT last_name , salary FROM employees WHERE salary > 1 1 000 ; #方式二:自連接 SELECT e2 .last_name , e2 . salary FROM employees e1 , employees e2 WHERE e1.last_name = ' Abel ' AND e1. ` salary ` < e2. ` salary `
#方式三:子查詢 SELECT last_name,salary FROM employees WHERE salary > ( SELECT salary FROM employees WHERE last_name = 'Abel' );
子查詢的基本使用
子查詢的基本語法結構

子查詢(內查詢)在主查詢之前一次執(zhí)行完成。
子查詢的結果被主查詢(外查詢)使用 。
注意事項
子查詢要包含在括號內
將子查詢放在比較條件的右側
單行操作符對應單行子查詢,多行操作符對應多行子查詢
子查詢的分類
分類方式1:
我們按內查詢的結果返回一條還是多條記錄,將子查詢分為 單行子查詢 、 多行子查詢 。

分類方式2:
我們按內查詢是否被執(zhí)行多次,將子查詢劃分為 相關(或關聯(lián))子查詢 和 不相關(或非關聯(lián))子查詢 。子查詢從數(shù)據(jù)表中查詢了數(shù)據(jù)結果,如果這個數(shù)據(jù)結果只執(zhí)行一次,然后這個數(shù)據(jù)結果作為主查詢的條件進行執(zhí)行,那么這樣的子查詢叫做不相關子查詢。
同樣,如果子查詢需要執(zhí)行多次,即采用循環(huán)的方式,先從外部查詢開始,每次都傳入子查詢進行查詢,然后再將結果反饋給外部,這種嵌套的執(zhí)行方式就稱為相關子查詢。
單行子查詢

代碼示例
題目:查詢工資大于149號員工工資的員工的信息

題目:返回job_id與141號員工相同,salary比143號員工多的員工姓名,job_id和工資
SELECT last_name, job_id, salary
FROM employees
WHERE job_id =
(SELECT job_id
FROM employees
WHERE employee_id = 141)
AND salary >
(SELECT salary
FROM employees
WHERE employee_id = 143);題目:返回公司工資最少的員工的last_name,job_id和salary
SELECT last_name, job_id, salary FROM employees WHERE salary = (SELECT MIN(salary) FROM employees);
HAVING中的子查詢
顯式員工的employee_id,last_name和location。其中,若員工department_id與location_id為1800的department_id相同,則location為’Canada’,其余則為’USA’。
SELECT employee_id, last_name, (CASE department_id WHEN (SELECT department_id FROM departments WHERE location_id = 1800) THEN 'Canada' ELSE 'USA' END) location FROM employees;
非法使用子查詢
SELECT employee_id, last_name FROM employees WHERE salary = (SELECT MIN(salary) FROM employees GROUP BY department_id);

多行子查詢
也稱為集合比較子查詢
內查詢返回多行
使用多行比較操作符
多行比較操作符

代碼示例
題目:返回其它job_id中比job_id為‘IT_PROG’部門任一工資低的員工的員工號、姓名、job_id 以及salary

題目:返回其它job_id中比job_id為‘IT_PROG’部門所有工資都低的員工的員工號、姓名、job_id以及id

題目:查詢平均工資最低的部門id
SELECT department_id
FROM employees
GROUP BY department_id
HAVING AVG(salary) <= ALL (
SELECT AVG(salary) avg_sal
FROM employees
GROUP BY department_id)SELECT department_id
FROM employees
GROUP BY department_id
HAVING AVG(salary) = (
SELECT MIN(avg_sal)
FROM (
SELECT AVG(salary) avg_sal
FROM employees
GROUP BY department_id
) dept_avg_sal
)到此這篇關于MySQL子查詢的使用詳解上篇的文章就介紹到這了,更多相關MySQL子查詢內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
mysqldump加-w參數(shù)備份數(shù)據(jù)時需要注意的事項
這篇文章主要介紹了mysqldump加-w參數(shù)備份數(shù)據(jù)時需要注意的事項,需要的朋友可以參考下2014-06-06
mysql中插入表數(shù)據(jù)中文亂碼問題的解決方法
mysql是我們項目中非經常常使用的數(shù)據(jù)型數(shù)據(jù)庫,下面這篇文章主要給大家介紹了關于mysql中插入表數(shù)據(jù)中文亂碼問題的解決方法,文中通過示例代碼介紹的非常詳細,需要的朋友可以參考借鑒,下面隨著小編來一起學習學習吧2018-09-09
解決MySQL因不能創(chuàng)建臨時文件而導致無法啟動的方法
這篇文章主要跟大家介紹了關于解決MySQL因不能創(chuàng)建臨時文件而導致無法啟動的方法,文中通過示例代碼介紹了詳細的解決方法,對大家具有一定的的參考學習價值,需要的朋友們下面來一起看看吧。2017-06-06

