大多數情況下,查詢關注的是表中所有行的一個子集,需要用到Where過濾,本文主要介紹過濾的條件連接符(AND, OR, (),NOT),條件類型(相等條件、範圍條件、成員條件、通配條件)以及當列名包含NULL值的注意事項。
1. 條件連接符
1) AND:a AND b,選取要a和b都爲真的數據子集
2) OR:a OR b,選取要a或b都爲真的數據子集
3) ():當條件爲3個或以上時,常常需要用到,比如 a AND (b OR c)
4) NOT:NOT a,選區非a的數據子集,NOT 對開發者來說,增加了對條件評估的難度,一般儘量避免使用:
如:WHERE end_date IS NULL
AND NOT (title = 'Teller' OR start_date < '2007-01-01')
可轉換爲:WHERE end_date IS NULL
AND title != 'Teller' AND start_date > '2007-01-01'
2. 條件類型
1) 相等條件,操作符 =,!=,<>
2) 範圍條件,操作符 >,<, between,例如:
SELECT emp_id, fname, lname, start_date
FROM employee
WHERE start_date < '2007-01-01';
WHERE start_date BETWEEN '2005-01-01' AND '2007-01-01';
使用BETWEEN是,跟這BETWEEN後的一定要是範圍的下限,AND後接範圍上限,否則會是空集,這是因爲BETWEEN a AND b等價於a<=x<=b
3) 成員條件,操作符 IN, NOT IN, 例如:
SELECT account_id, product_cd, cust_id, avail_balance
FROM account
WHERE product_cd IN ('CHK','SAV','CD','MM');
IN 後面也可以接子查詢,如:
SELECT account_id, product_cd, cust_id, avail_balance
FROM account
WHERE product_cd IN (SELECT product_cd FROM product
WHERE product_type_cd = 'ACCOUNT');
4) 匹配條件,通配符:"_"表示一個字符通配符,“%”表示任意個字符通配符,關鍵詞LIKE
SELECT lname
FROM employee
WHERE lname LIKE '_a%e%'; #第二個字符爲a,且後面有e字符
SELECT emp_id, fname, lname
FROM employee
WHERE lname LIKE 'F%' OR lname LIKE 'G%'; # 查找姓氏以F和G開頭的員工姓名
3. NULL條件
注意:表達式爲"IS NULL",不能寫出"=NULL",兩個NULL只也不能判斷相等,如:
如果改成 = NULL, 則查詢結果是空集但不會報錯(不熟悉SQL常犯錯誤):
如果值中包括NULL, 則在使用"!="時要考慮到NULL值的數據,因爲"!="只對有值的情況進行判斷:
例如:查找上級ID不是6(Helen Fleming)的所有員工
SELECT emp_id, fname, lname, superior_emp_id
FROM employee
WHERE superior_emp_id != 6;
結果不包含superior_emp_id列爲NULL的Michael Smith
SELECT emp_id, fname, lname, superior_emp_id
FROM employee
WHERE superior_emp_id != 6 OR superior_emp_id IS NULL;