Oracle 专题
专题目录
您的位置:database > Oracle专题 > Oracle In子句
Oracle In子句
作者:--    发布时间:2019-11-20

在本教程中将学习如何使用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
网站声明:
本站部分内容来自网络,如您发现本站内容
侵害到您的利益,请联系本站管理员处理。
联系站长
373515719@qq.com
关于本站:
编程参考手册