Oracle In子句

2022-03-09 17:33 更新

Oracle IN 運(yùn)算符可以用來(lái)確定值是否與列表或子查詢中的任何值相匹配,本文就將為大家?guī)?lái) Oracle IN 運(yùn)算符的具體用法。

Oracle IN語(yǔ)法: 

確定表達(dá)式是否與值列表匹配的 Oracle IN 運(yùn)算符的語(yǔ)法如下所示:

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

并且表達(dá)式的語(yǔ)法與子查詢匹配:

expression [NOT] IN (subquery)

參數(shù)

在上面語(yǔ)法中,這里將介紹每個(gè)參數(shù)含義:

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

返回值

如果表達(dá)式(expression)的值等于值列表中的任何值或由子查詢返回的結(jié)果集,則 IN 運(yùn)算符返回 true。 否則,它返回 false。

NOT 運(yùn)算符否定 IN 運(yùn)算符的結(jié)果。

Oracle IN實(shí)例

以下面的這兩種表為例:

1

1. Oracle IN 示例

以下語(yǔ)句查找所有銷售員 ID 為54,55和56所負(fù)責(zé)的訂單:

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

執(zhí)行以上代碼可以得到以下結(jié)果:

2

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

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

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

3

2. Oracle NOT IN示例

這個(gè)示例演示如何查找狀態(tài)(status)不是"Shipped"或"Canceled"的訂單:

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

執(zhí)行上面查詢語(yǔ)句返回狀態(tài)(status)列的值不是"Shipped"或"Canceled"的銷售訂單信息,如下所示:

4

3. Oracle IN 子查詢示例

以下示例返回負(fù)責(zé)訂單狀態(tài)為取消(Canceled)的銷售員的ID,名字和姓氏,參考以下查詢語(yǔ)句

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;

執(zhí)行上面查詢語(yǔ)句,得到以下結(jié)果:

5

在這個(gè)例子中,子查詢首先執(zhí)行并返回一個(gè)銷售員ID列表:

SELECT
    DISTINCT salesman_id
FROM
    orders
WHERE
    status = 'Canceled'

執(zhí)行上面查詢語(yǔ)句,得到以下結(jié)果 

6

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


以上內(nèi)容是否對(duì)您有幫助:
在線筆記
App下載
App下載

掃描二維碼

下載編程獅App

公眾號(hào)
微信公眾號(hào)

編程獅公眾號(hào)