Oracle In(匹配)子句


Oracle IN運算符可以用來確定值是否與列表或子查詢中的任何值相匹配,本文就將為大家帶來Oracle IN運算符的具體用法。

Oracle IN語法: 

確定表達式是否與值列表匹配的Oracle IN運算符的語法如下所示:

expression [NOT] IN (v1,v2,...)

並且表達式的語法與子查詢匹配:

expression [NOT] IN (subquery)

參數

在上面語法中,這里將介紹每個參數含義:

  • expression - 該表達式(expression)是任何有效的表達式,它可以是要匹配的表的列。
  • v1, v2, v3.. - IN運算符后面是逗號分隔值列表,用於測試匹配。所有值必須與表達式具有相同的數據類型。
  • subquery - 子查詢返回一列的結果集以測試匹配。該列還必須具有與表達式相同的數據類型。

返回值

如果表達式(expression)的值等於值列表中的任何值或由子查詢返回的結果集,則IN運算符返回true。 否則,它返回false。

NOT運算符否定IN運算符的結果。

Oracle IN實例

以下面的這兩種表為例:

1

1. Oracle IN示例

以下語句查找所有銷售員ID為54,55和56所負責的訂單:

SELECT order_id,customer_id,status,salesman_id FROM orders WHERE salesman_id IN (54,55,56) ORDER BY order_id;

執行以上代碼可以得到以下結果:

2

如上圖中所示,查詢結果集返回了salesman_id列中值為54,55或56的所有訂單。同樣,以下示例將檢索狀態(status)列的值為"Pending"或"Canceled"的銷售訂單信息:

SELECT order_id, customer_id, status, salesman_id FROM orders WHERE status IN('Pending','Canceled') ORDER BY order_id;

執行上面查詢語句返回狀態(status)列的值為"Pending"或"Canceled"的銷售訂單信息,如下所示:

3

2. Oracle NOT IN示例

這個示例演示如何查找狀態(status)不是"Pending"或"Canceled"的訂單:

SELECT order_id, customer_id, status, salesman_id FROM orders WHERE status NOT IN( 'Shipped', 'Canceled') ORDER BY order_id;

執行上面查詢語句返回狀態(status)列的值不是"Pending"或"Canceled"的銷售訂單信息,如下所示:

4

3. Oracle IN子查詢示例

以下示例返回負責訂單狀態為取消(Canceled)的銷售員的ID,名字和姓氏,參考以下查詢語句

SELECT employee_id, first_name, last_name FROM employees WHERE employee_id IN( SELECT DISTINCT salesman_id FROM orders WHERE status = 'Canceled' ) ORDER BY first_Name;

執行上面查詢語句,得到以下結果:

5

在這個例子中,子查詢首先執行並返回一個銷售員ID列表:

SELECT DISTINCT salesman_id FROM orders WHERE status = 'Canceled'

執行上面查詢語句,得到以下結果 

6

這些銷售人員id用於外部查詢,查找所有員工的ID與銷售員ID列表中的任何id相同。

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM