Oracle In子句
Oracle In子句
作者:初生不惑 Oracle基礎 評論:0 條 Oracle技術QQ群:175248146在本教程中,您將學習如何使用Oracle IN
運算符來確定值是否與列表或子查詢中的任何值相匹配。
Oracle IN操作符介紹
Oracle IN
運算符確定值是否匹配列表或子查詢中的任何值。
註:子查詢是嵌套在另一個查詢中的查詢,可通過在子查詢教程中了解子查詢用法。
確定表達式是否與值列表匹配的Oracle IN
運算符的語法如下所示:
expression [NOT] IN (v1,v2,...)
SQL
並且表達式的語法與子查詢匹配:
expression [NOT] IN (subquery)
SQL
參數
在上面語法中,這裏將介紹每個參數含義:
- expression - 該表達式(expression)是任何有效的表達式,它可以是要匹配的表的列。
- v1, v2, v3.. -
IN
運算符後面是逗號分隔值列表,用於測試匹配。所有值必須與表達式具有相同的數據類型。 - subquery - 子查詢返回一列的結果集以測試匹配。該列還必須具有與表達式相同的數據類型。
返回值
如果表達式(expression)的值等於值列表中的任何值或由子查詢返回的結果集,則IN
運算符返回true
。 否則,它返回false
。
NOT
運算符否定IN
運算符的結果。
Oracle IN運算符示例
我們將使用示例數據庫中的orders
employees
表進行演示:
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;
SQL
執行上面查詢語句,得到以下結果 -
如上圖中所示,查詢結果集返回了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;
SQL
執行上面查詢語句返回狀態(status
)列的值為"Pending"
或"Canceled"
的銷售訂單信息,如下所示 -
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;
SQL
執行上面查詢語句返回狀態(status
)列的值不是"Pending"
或"Canceled"
的銷售訂單信息,如下所示 -
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;
SQL
執行上面查詢語句,得到以下結果 -
在這個例子中,子查詢首先執行並返回一個銷售員ID列表:
SELECT
DISTINCT salesman_id
FROM
orders
WHERE
status = ‘Canceled‘
SQL
執行上面查詢語句,得到以下結果 -
這些銷售人員id
用於外部查詢,查找所有員工的ID
與銷售員ID
列表中的任何id
相同。
4. Oracle NOT IN子查詢示例
請參閱以下customers
和orders
表的ER圖:
以下示例使用NOT IN
來查找尚未下過任何訂單的客戶:
SELECT
customer_id, name
FROM customers
WHERE
customer_id NOT IN(
SELECT
customer_id
FROM
orders
);
SQL
執行上面查詢語句,得到以下結果 -
5. Oracle IN與OR運算符
以下示例顯示如何獲得銷售員ID為60
,61
和62
的銷售訂單:
SELECT
customer_id, status, salesman_id
FROM
orders
WHERE
salesman_id IN(60, 61, 62)
ORDER BY
customer_id;
SQL
執行上面查詢語句,得到以下結果 -
上面語句相當於:
SELECT
customer_id,
status,
salesman_id
FROM
orders
WHERE
salesman_id = 60
OR salesman_id = 61
OR salesman_id = 62
ORDER BY
customer_id;
SQL
請註意,表達式:
salesman_id NOT IN (60,61,62);
SQL
與以下語句具有相同的效果:
salesman_id = 60
AND salesman_id = 61
AND salesman_id = 62;
SQL
在本教程中,您已學習如何使用Oracle IN
運算符來查詢與值列表或子查詢匹配的數據。
Oracle In子句