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实例
以下面的这两种表为例:
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相同。
相关文章
- Oracle简介
- Oracle Where子句
- Oracle Fetch子句
- Oracle Like子句
- Oracle Ascii()函数
- Oracle Compose()函数
- Oracle Concat()函数
- Oracle ||运算符
- Memcached 教程
- Memcached incr 与 decr 命令
- DB2数据库
- DB2备份和恢复
- oracle中对JSON数据处理的详细指南
- 一文详解Oracle存储过程
- Oracle中时间日期转化函数to_date和to_char的具体使用
- Oracle数据库表空间超详细介绍
- oracle导出数据到文本、从文本导入数据的详细步骤
- Oracle导出文本文件的三种方法(spool,UTL_FILE,sqluldr2)
- Oracle 19c创建数据库的完整步骤(详细明了)
- Oracle range时间范围自动分区的创建方式