zoukankan      html  css  js  c++  java
  • Oracle In子句

    Oracle In子句

    在本教程中,您将学习如何使用Oracle IN运算符来确定值是否与列表或子查询中的任何值相匹配。

    Oracle IN操作符介绍

    Oracle IN运算符确定值是否匹配列表或子查询中的任何值。

    注:子查询是嵌套在另一个查询中的查询,可通过在子查询教程中了解子查询用法。

    确定表达式是否与值列表匹配的Oracle IN运算符的语法如下所示:

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

    并且表达式的语法与子查询匹配:

    expression [NOT] IN (subquery)
    
    SQL

    参数

    在上面语法中,这里将介绍每个参数含义:

    • 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;
    
    SQL

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

    如上图中所示,查询结果集返回了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;
    
    SQL

    执行上面查询语句返回状态(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;
    
    SQL

    执行上面查询语句返回状态(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;
    
    SQL

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

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

    SELECT
        DISTINCT salesman_id
    FROM
        orders
    WHERE
        status = 'Canceled'
    
    SQL

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

    这些销售人员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
        );
    
    SQL

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

    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;
    
    SQL

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

    上面语句相当于:

    SELECT
        customer_id,
        status,
        salesman_id
    FROM
        orders
    WHERE
        salesman_id = 60
        OR salesman_id = 61
        OR salesman_id = 62
    ORDER BY
        customer_id;
    
    SQL

    请注意,表达式:

    salesman_id NOT IN (60,61,62);
    
    SQL

    与以下语句具有相同的效果:

    salesman_id = 60
    AND salesman_id = 61
    AND salesman_id = 62;
    
    SQL

    在本教程中,您已学习如何使用Oracle IN运算符来查询与值列表或子查询匹配的数据。

  • 相关阅读:
    超线程、多核、多处理器
    视图
    面试题27:连续子数组的最大和
    Java实现 蓝桥杯油漆问题
    Java实现 蓝桥杯油漆问题
    Java实现 蓝桥杯油漆问题
    Java实现 蓝桥杯油漆问题
    Java实现第七届蓝桥杯国赛 赢球票
    Java实现第七届蓝桥杯国赛 赢球票
    Java实现第七届蓝桥杯国赛 赢球票
  • 原文地址:https://www.cnblogs.com/youqc/p/9359226.html
Copyright © 2011-2022 走看看