Oracle In子句
Oracle IN運(yùn)算符可以用來確定值是否與列表或子查詢中的任何值相匹配,本文就將為大家?guī)鞳racle IN運(yùn)算符的具體用法。
Oracle IN語法:
確定表達(dá)式是否與值列表匹配的Oracle IN運(yùn)算符的語法如下所示:
expression [NOT] IN (v1,v2,...)
并且表達(dá)式的語法與子查詢匹配:
expression [NOT] IN (subquery)
參數(shù)
在上面語法中,這里將介紹每個(gè)參數(shù)含義:
- expression - 該表達(dá)式(expression)是任何有效的表達(dá)式,它可以是要匹配的表的列。
- v1, v2, v3.. - IN運(yùn)算符后面是逗號(hào)分隔值列表,用于測試匹配。所有值必須與表達(dá)式具有相同的數(shù)據(jù)類型。
- subquery - 子查詢返回一列的結(jié)果集以測試匹配。該列還必須具有與表達(dá)式相同的數(shù)據(jù)類型。
返回值
如果表達(dá)式(expression)的值等于值列表中的任何值或由子查詢返回的結(jié)果集,則IN運(yùn)算符返回true。 否則,它返回false。
NOT運(yùn)算符否定IN運(yùn)算符的結(jié)果。
Oracle IN實(shí)例
以下面的這兩種表為例:
1. Oracle IN示例
以下語句查找所有銷售員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é)果:
如上圖中所示,查詢結(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í)行上面查詢語句返回狀態(tài)(status)列的值為"Pending"或"Canceled"的銷售訂單信息,如下所示:
2. Oracle NOT IN示例
這個(gè)示例演示如何查找狀態(tài)(status)不是"Pending"或"Canceled"的訂單:
SELECT order_id, customer_id, status, salesman_id FROM orders WHERE status NOT IN( 'Shipped', 'Canceled') ORDER BY order_id;
執(zhí)行上面查詢語句返回狀態(tài)(status)列的值不是"Pending"或"Canceled"的銷售訂單信息,如下所示:
3. Oracle IN子查詢示例
以下示例返回負(fù)責(zé)訂單狀態(tài)為取消(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;
執(zhí)行上面查詢語句,得到以下結(jié)果:
在這個(gè)例子中,子查詢首先執(zhí)行并返回一個(gè)銷售員ID列表:
SELECT DISTINCT salesman_id FROM orders WHERE status = 'Canceled'
執(zhí)行上面查詢語句,得到以下結(jié)果
這些銷售人員id用于外部查詢,查找所有員工的ID與銷售員ID列表中的任何id相同。
- Oracle簡介
- Oracle Where子句
- Oracle Fetch子句
- Oracle Like子句
- Oracle Ascii()函數(shù)
- Oracle Compose()函數(shù)
- Oracle Concat()函數(shù)
- Oracle ||運(yùn)算符
- Memcached 教程
- Memcached incr 與 decr 命令
- DB2數(shù)據(jù)庫
- DB2備份和恢復(fù)
- oracle中對JSON數(shù)據(jù)處理的詳細(xì)指南
- 一文詳解Oracle存儲(chǔ)過程
- Oracle中時(shí)間日期轉(zhuǎn)化函數(shù)to_date和to_char的具體使用
- Oracle數(shù)據(jù)庫表空間超詳細(xì)介紹
- oracle導(dǎo)出數(shù)據(jù)到文本、從文本導(dǎo)入數(shù)據(jù)的詳細(xì)步驟
- Oracle導(dǎo)出文本文件的三種方法(spool,UTL_FILE,sqluldr2)
- Oracle?19c創(chuàng)建數(shù)據(jù)庫的完整步驟(詳細(xì)明了)
- Oracle?range時(shí)間范圍自動(dòng)分區(qū)的創(chuàng)建方式