当前位置: 首页 > article >正文

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实例

以下面的这两种表为例:

在这里插入图片描述

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;

执行以上代码可以得到以下结果:

在这里插入图片描述

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

在这里插入图片描述

2. Oracle NOT IN示例

这个示例演示如何查找状态(status)不是"Shipped"或"Canceled"的订单:

SELECT
    order_id, customer_id, status, salesman_id
FROM
    orders
WHERE
    status NOT IN( 'Shipped', 'Canceled')
ORDER BY
    order_id;

执行上面查询语句返回状态(status)列的值不是"Shipped"或"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相同。
shenwang_666


http://www.kler.cn/a/392313.html

相关文章:

  • SQL从入门到实战
  • 基于SMT32U575RIT单片机-中断练习
  • 如何在Windows上编译OpenCV4.7.0
  • touch详讲
  • 微信小程序中 “页面” 和 “非页面” 的区别
  • CDP集成Hudi实战-spark shell
  • 每日OJ题_牛客_春游_贪心+数学_C++_Java
  • Spark:背压机制
  • 南山前海13元一份的猪脚饭
  • mysql 几种启动和关闭mysql方法介绍
  • 青少年编程与数学 02-003 Go语言网络编程 18课题、Go语言Session编程
  • 大语言模型:解锁自然语言处理的无限可能
  • 鸿蒙UI开发——实现环形文字
  • 硬件---1电路设计安全要点以及欧姆定律
  • 【月之暗面kimi-注册/登录安全分析报告】
  • 如何在Puppeteer中实现表单自动填写与提交:问卷调查
  • k8s更新
  • 【Element】vue2 el-table scope.row 更改数据,试图没有更新
  • 《情商》提升:增强自我意识,学会与情绪共处
  • 请描述一下Spring Boot中的@SpringBootApplication注解的工作原理?
  • 动态规划中处理边界条件的常见策略
  • 【Lucene】从文本到索引:Lucene如何构建索引
  • 第十一天 线性代数基础
  • 磐石云黑名单管理系统
  • Android ANR分析总结
  • 石油安全理论知识题库 考试宝在线刷题