数据库教程-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表进行演示:

Oracle In子句

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; 

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

Oracle In子句

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

Oracle In子句

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

Oracle In子句

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; 

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

Oracle In子句

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

SELECT     DISTINCT salesman_id FROM     orders WHERE     status = 'Canceled' 

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

Oracle In子句

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

4. Oracle NOT IN子查询示例

请参阅以下customersorders表的ER图:

Oracle In子句

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

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

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

Oracle In子句

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; 

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

Oracle In子句

上面语句相当于:

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

  

从零到一,创造未来!跨零综合IT问题解决服务站,欢迎你的到来。Oracle数据库教程 只为你绽放。

本文固定链接: http://kua0.com/2019/01/17/数据库教程-oracle-in子句/

为您推荐

发表评论

电子邮件地址不会被公开。 必填项已用*标注