SELECT select_list
FROM table
WHERE exPR Operator
(SELECT select_list
FROM table);
?子查詢(內(nèi)查詢) 在主查詢之前一次執(zhí)行完成。子查詢的結(jié)果被主查詢(外查詢)使用 實例:在employees表中查詢,誰的工資比Abel的工資高?select last_namefrom employees where salary >( select salary from employees where last_name='Able')單行子查詢*只返回單行*使用單行操作符=
>=
<
<=
<>
執(zhí)行單行子查詢題目:返回job_id與141號員工相同,salary比143號員工多的員工
姓名,job_id和工資
SELECTlast_name,job_id,salary
FROM employees
WHERE job_id=
(SELECTjob_id
FROM employees
WHERE employee_id= 141)
AND salary >
(SELECT salary
FROM employees
WHERE employee_id= 143);
在查詢中使用組函數(shù)
SELECTlast_name,job_id, salary
FROM employees
WHERE salary =
(SELECT MIN(salary)
FROM employees);
子查詢中的HAVING 語句
[
?不能在 WHERE 子句中使用組函數(shù)。?可以在 HAVING 子句中使用組函數(shù)。]SELECT department_id,MIN(salary)
FROM employees
GROUPBY department_id
HAVING MIN(salary) >
(SELECT MIN(salary)
FROM employees
WHERE department_id= 50);
多行子查詢
*返回多行
*使用多行比較符
IN 等于列表的任意一個
ANY 和子查詢返回的某一個值
ALL 和子查詢返回的所有值進行比較
題目:返回其它部門中比job_id為‘IT_PROG’部門任一工資低的員工的員
工號、姓名、job_id 以及salary
SELECT employee_id,last_name,job_id, salary
FROM employees
WHERE salary < ANY
(SELECTsalary
FROM employees
WHERE job_id = 'IT_PROG')
AND job_id <> 'IT_PROG';
|
新聞熱點
疑難解答
圖片精選