oracle中in函数在子查询使用,Oracle In

oracle函数 的 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运算符示例

我们将使用中的orders和employees表进行演示:

688bbabf6a6536b7d2395f62305ea74a.png

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;

执行上面查询语句,得到以下结果 -

e6d84f586f8dad0a9b5576d3bb4cb7f7.png

如上图中所示,查询结果集返回了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"的销售订单信息,如下所示 -

394509e8635f0de21717932bc5d53420.png

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"的销售订单信息,如下所示 -

8dc5aa6c0fd289f2b513cdfaa1c697be.png

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;

执行上面查询语句,得到以下结果 -

75b9d598f9c77d7bd41027a08c530a30.png

在这个例子中,子查询首先执行并返回一个销售员ID列表:

SELECT

DISTINCT salesman_id

FROM

orders

WHERE

status = 'Canceled'

执行上面查询语句,得到以下结果 -

9cbfbd54b937f8c303cae7119ff5a77f.png

这些销售人员id用于外部查询,查找所有员工的ID与销售员ID列表中的任何id相同。

4. Oracle NOT IN子查询示例

请参阅以下customers和orders表的ER图:

b0f6805366be24be81b24d0ee43801e3.png

以下示例使用NOT IN来查找尚未下过任何订单的客户:

SELECT

customer_id, name

FROM customers

WHERE

customer_id NOT IN(

SELECT

customer_id

FROM

orders

);

执行上面查询语句,得到以下结果 -

a66cf29c346685fba602046cb80ee9e5.png

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;

执行上面查询语句,得到以下结果 -

274be481b8ab366f2ea527ecde00b500.png

上面语句相当于:

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运算符来查询与值列表或子查询匹配的数据。

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值