SQL查詢過濾Where子句用法

大多數情況下,查詢關注的是表中所有行的一個子集,需要用到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;

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章