Oracle In子句

作者:初生不惑 Oracle基础 评论:0 条 Oracle技术QQ群:175248146

在本教程中,您将学习如何使用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运算符来查询与值列表或子查询匹配的数据。

Oracle In子句的更多相关文章

  1. Oracle Like子句

    Oracle Like子句 作者:初生不惑 Oracle基础 评论:0 条 Oracle技术QQ群:175248146 在本教程中,您将学习如何使用Oracle LIKE运算符来测试列中的值是否与指定 ...

  2. Oracle Between子句

    Oracle Between子句 作者:初生不惑 Oracle基础 评论:0 条 Oracle技术QQ群:175248146 在本教程中,您将学习如何使用Oracle BETWEEN运算符来选择值在一 ...

  3. Oracle Fetch子句

    Oracle Fetch子句 作者:初生不惑 Oracle基础 评论:0 条 Oracle技术QQ群:175248146 在本教程中,将学习如何使用Oracle FETCH子句来限制查询返回的行数. ...

  4. Oracle Or子句

    Oracle Or子句 作者:初生不惑 Oracle基础 评论:0 条 Oracle技术QQ群:175248146 在本教程中,我们来学习如何使用Oracle OR运算符来组合两个或更多的布尔表达式. ...

  5. Oracle And子句

    Oracle And子句 作者:初生不惑 Oracle基础 评论:0 条 Oracle技术QQ群:175248146 在本教程中,将学习如何使用Oracle AND运算符来组合两个或更多的布尔表达式. ...

  6. Oracle Where子句

    Oracle Where子句 作者:初生不惑 Oracle基础 评论:0 条 Oracle技术QQ群:175248146 在本教程中,将学习如何使用Oracle WHERE子句来指定过滤的条件返回符合 ...

  7. oracle排序子句的特殊写法与ORA-01785错误

    刚刚写的SQL语句在执行的时候报[ORA-01785: ORDER BY item must be the number of a SELECT-list expression]错误,于是自己百度了一 ...

  8. oracle SELECT子句中避免使用 ‘ * ‘

    当你想在SELECT子句中列出所有的COLUMN时,使用动态SQL列引用 ‘*’ 是一个方便的方法. 不幸的是,这是一个非常低效的方法. 实际上,ORACLE在解析的过程中, 会将’*’ 依次转换成所 ...

  9. oracle WHERE子句中的连接顺序

    ORACLE采用自下而上的顺序解析WHERE子句,根据这个原理,表之间的连接必须写在其他WHERE条件之前, 那些可以过滤掉最大数量记录的条件必须写在WHERE子句的末尾. 例如: (低效,执行时间1 ...

随机推荐

  1. Java中字母大小写的转换

    例:String str = "AbC"; 把字符串所有字母变成小写: System.out.println(str.toLowerCase()); 把字符串所有字母大写: Sys ...

  2. Java第二周总结

    一.Java 基础程序设计 第一章: (1)在Java中源文件的扩展名为.java,编译Java源程序文件产生相应的字节码文件扩展名为.class (2)public class定义要求类名称保持一致 ...

  3. SET ANSI_NULL ON 和 SET QUOTED_IDENTIFIFR ON

    本文转自:https://blog.csdn.net/qq112212qq/article/details/84578263 SET ANSI_NULL ON : 判断非空:where colunm ...

  4. HNUSTOJ 1601:名字缩写

    1601: 名字缩写 时间限制: 1 Sec  内存限制: 128 MB 提交: 288  解决: 80 [提交][状态][讨论版] 题目描述 Noname老师有一个班的学生名字要写,但是他太懒了,想 ...

  5. .net WebApi使用swagger 美化接口文档

    本文将一步步演示如何用swagger美化WebApi接口文档,为接口文档添加接口名称说明,为请求参数和返回数据结构字段含义添加注释说明 一.为WebApi项目安装Swagger 首先我们新建一个Web ...

  6. 【C#】获取"我的电脑"的名字,如This PC、这台计算机

    原文:[C#]获取"我的电脑"的名字,如This PC.这台计算机 版权声明:本文为博主原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明. 本文链接: ...

  7. 在Python中使用protobuf2.6.1 string format utf-8 and unicode error

    版本信息: protobuf: v2.6.1 python: 2.7 关于在Python中使用protobuf时 string格式字段的编码问题 在python中编码格式多采用utf-8格式.而pro ...

  8. ubuntu install xsltproc docbook-xsl docbook-xml

    问题一: $ makexsltproc --output phtml/ param.xsl ./pxml/mainbook.xmlmake: xsltproc: Command not foundma ...

  9. maven多模块tomcat启动报 NoClassDefFoundError:com/test/main/message

    maven多模块tomcat启动报 NoClassDefFoundError:com/test/main/message 扫描不到 添加子模块jar包

  10. 流畅的Python (Fluent Python) —— 第二部分01

    2.1 内置序列类型概览 Python 标准库用 C 实现了丰富的序列类型,列举如下. 容器序列 list. tuple 和 collections.deque 这些序列能存放不同类型的数据. 扁平序 ...