Oracle In子句
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运算符示例
我们将使用示例数据库中的orders
和employees
表进行演示:
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
)不是"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子查询示例
请参阅以下customers
和orders
表的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
,61
和62
的销售订单:
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
运算符来查询与值列表或子查询匹配的数据。
Oracle In子句的更多相关文章
- Oracle Like子句
Oracle Like子句 作者:初生不惑 Oracle基础 评论:0 条 Oracle技术QQ群:175248146 在本教程中,您将学习如何使用Oracle LIKE运算符来测试列中的值是否与指定 ...
- Oracle Between子句
Oracle Between子句 作者:初生不惑 Oracle基础 评论:0 条 Oracle技术QQ群:175248146 在本教程中,您将学习如何使用Oracle BETWEEN运算符来选择值在一 ...
- Oracle Fetch子句
Oracle Fetch子句 作者:初生不惑 Oracle基础 评论:0 条 Oracle技术QQ群:175248146 在本教程中,将学习如何使用Oracle FETCH子句来限制查询返回的行数. ...
- Oracle Or子句
Oracle Or子句 作者:初生不惑 Oracle基础 评论:0 条 Oracle技术QQ群:175248146 在本教程中,我们来学习如何使用Oracle OR运算符来组合两个或更多的布尔表达式. ...
- Oracle And子句
Oracle And子句 作者:初生不惑 Oracle基础 评论:0 条 Oracle技术QQ群:175248146 在本教程中,将学习如何使用Oracle AND运算符来组合两个或更多的布尔表达式. ...
- Oracle Where子句
Oracle Where子句 作者:初生不惑 Oracle基础 评论:0 条 Oracle技术QQ群:175248146 在本教程中,将学习如何使用Oracle WHERE子句来指定过滤的条件返回符合 ...
- oracle排序子句的特殊写法与ORA-01785错误
刚刚写的SQL语句在执行的时候报[ORA-01785: ORDER BY item must be the number of a SELECT-list expression]错误,于是自己百度了一 ...
- oracle SELECT子句中避免使用 ‘ * ‘
当你想在SELECT子句中列出所有的COLUMN时,使用动态SQL列引用 ‘*’ 是一个方便的方法. 不幸的是,这是一个非常低效的方法. 实际上,ORACLE在解析的过程中, 会将’*’ 依次转换成所 ...
- oracle WHERE子句中的连接顺序
ORACLE采用自下而上的顺序解析WHERE子句,根据这个原理,表之间的连接必须写在其他WHERE条件之前, 那些可以过滤掉最大数量记录的条件必须写在WHERE子句的末尾. 例如: (低效,执行时间1 ...
随机推荐
- “AIIA”杯-国家电网-电力专业领域词汇挖掘
十一之前一直在做“电力领域的词典构建”任务,今天也去聆听了前五支队伍的报告,现结合这段时间来的项目经历,写一下自己的若干心得. 电力领域的词典构建——方法1(非监督学习) 在电力领域词典构建心得1.0 ...
- Java IO NIO详细讲解
1.IO Java IO概述 2.NIO Java NIO浅析
- [转帖]OEM、ODM、OBM分别是什么?
OEM.ODM.OBM分别是什么? https://blog.csdn.net/liangtianmeng/article/details/83215500 感觉很多地方说明的都不对 OEM 别人的产 ...
- Windows node.js安装运行npm显示类似"ENOENT, stat 'C:\Users\XXXX\AppData\Roaming\npm'错误
这个错误是在玩一个小的博客的时候,使用到node.js,正好使用的是windows系统就安装了一个windows32的node.js版本 结果一运行npm就出现如上的错误,后来发现,只要在上面提到的目 ...
- Linux 最常用命令整理,建议收藏!
Linux是目前应用最广泛的服务器操作系统,基于Unix,开源免费,由于系统的稳定性和安全性,市场占有率很高,几乎成为程序代码运行的最佳系统环境. linux不仅可以长时间的运行我们编写的程序代码,还 ...
- Vue Element使用第三库icon图标
一:引入单设图标 1.打开 阿里icon,注册 >登录>图标管理>我的项目 2.新建项目 返回阿里icon首页,点进去你想要的icon库,因为没有批量导入购物车,所以一般情况下需要一 ...
- 【转】海量数据解决思路之BitMap
转载(http://zengzhaozheng.blog.51cto.com/8219051/1404108) 一.概述 本文将讲述Bit-Map算法的相关原理,Bit-Map算法的一些利用场景,例如 ...
- 计算视图相对坐标时convertPoint:toView: ,UIApplication sharedApplication - keyWindow is nil?
UIWindow *window = [UIApplication sharedApplication].keyWindow; window 为nil的原因:在指定rootViewController ...
- AFNetworking2.0源码解析<四>
结构 AFURLResponseSerialization负责解析网络返回数据,检查数据是否合法,把NSData数据转成相应的对象,内置的转换器有json,xml,plist,image,用户可以很方 ...
- Keycode含义
keycode 是键盘上每一个按键对应的码keycode如下 :keycode 0 = keycode 1 = keycode 2 = keycode 3 = keycode 4 = keycode ...