oracle sql查询中用in列表中最大表达式数大于1000的处理

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了oracle sql查询中用in列表中最大表达式数大于1000的处理相关的知识,希望对你有一定的参考价值。

oracle sql查询中用in列表中最大表达式数大于1000时,会报异常! 我是从数据库中:
String sql= "select student_number from student",
查询后学号中的数据存入List集合中: List listString = JdbcTemplate.queryForList(sql); sql查询出来后的数据student_number共有33450条记录,我要从这些学号中查询数据,将这些学号放在stringBuffer strBuffer里面, student_number in (。。。),in里面是33450条记录。问如何处理啊?????

是的。oracle默认表达式数不允许超过1000。

最简单的办法是把这些学号导入到一个临时表。
然后两表关联。
参考技术A 用with table as语句就行了。用这种方式相当于建一个临时表,参考下面文章:
http://blog.csdn.net/iamlaosong/article/details/7061723
参考技术B 不清楚你要干啥 参考技术C 用游标分块处理。 参考技术D 分页试试。

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 sql查询中用in列表中最大表达式数大于1000的处理的主要内容,如果未能解决你的问题,请参考以下文章

IN 查询时出现ORA-01795:列表中的最大表达式数为1000解决方法

解决Oracle使用in语句不能超过1000问题

解决Oracle使用in语句不能超过1000问题

ORA-01795: 列表中的最大表达式数为 1000

Oracle的IN vs OR,哪个更快?

Sql语句报ORA-01795: 列表中的最大表达式数为 1000