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運算符示例

我們將使用示例資料庫中的ordersemployees表進行演示:

1. Oracle IN示例

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

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

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

如上圖中所示,查詢結果集返回了salesman_id列中值為54,5556的所有訂單。同樣,以下示例將檢索狀態(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"的銷售訂單資訊,如下所示 -

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"的銷售訂單資訊,如下所示 -

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;

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

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

SELECT
    DISTINCT salesman_id
FROM
    orders
WHERE
    status = 'Canceled'

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

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

4. Oracle NOT IN子查詢示例

請參閱以下customersorders表的ER圖:

以下示例使用NOT IN來查找尚未下過任何訂單的客戶:

SELECT
    customer_id, name
FROM customers
WHERE
    customer_id NOT IN(
        SELECT
            customer_id
        FROM
            orders
    );

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

5. Oracle IN與OR運算符

以下示例顯示如何獲得銷售員ID為60,6162的銷售訂單:

SELECT
    customer_id, status, salesman_id
FROM
    orders
WHERE
    salesman_id IN(60, 61, 62)
ORDER BY
    customer_id;

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

上面語句相當於:

SELECT
    customer_id,
    status,
    salesman_id
FROM
    orders
WHERE
    salesman_id = 60
    OR salesman_id = 61
    OR salesman_id = 62
ORDER BY
    customer_id;

請注意,運算式:

salesman_id NOT IN (60,61,62);

與以下語句具有相同的效果:

salesman_id = 60
AND salesman_id = 61
AND salesman_id = 62;

在本教學中,您已學習如何使用Oracle IN運算符來查詢與值列表或子查詢匹配的數據。


以下是糾正/補充內容:

SELECT customer_id status salesman_idFROM ordersWHERE salesman_id IN60 61 62ORDER BY customer_id語句運行結果與圖片所示不同  提交時間:2019-08-30
上一篇: Oracle Fetch子句 下一篇: Oracle Between子句