Java中使用List传入Oracle的IN查询

Java中使用List传入Oracle的IN查询时,若元素数量超过1000会报错‌,需通过分组处理避免此限制。

1、问题原因

Oracle数据库对IN子句的元素数量有限制(最多1000个),超过时会抛出ORA-01795错误。

2、解决方案

‌(1)数组分组处理‌

按固定分组数或每组元素数分割List,生成多个IN子句。

示例代码:

public static List<List<T>> averageAssign(List<T> source, int n) {

// 按分组数分割

}

public static List<List<T>> averageAssignByPer(List<T> source, int n) {

// 按每组元素数分割

}

‌(2)拼接多个IN条件‌

使用OR连接多个IN子句,避免单个子句超限。

示例代码:

public String splitInCondition(List<String> dataList, String columnName) {

StringBuilder sqlBuilder = new StringBuilder();

int count = 0;

while (count < dataList.size()) {

if ((count + 1) % 1000 == 0) {

sqlBuilder.append(") OR ").append(columnName).append(" IN (");

}

sqlBuilder.append("'").append(dataList.get(count)).append("',");

count++;

}

sqlBuilder.deleteCharAt(sqlBuilder.length() - 1).append(")");

return sqlBuilder.toString();

}

(3) ‌存储过程传参‌

将List转换为Oracle数组,通过存储过程批量插入。

示例代码:

public static ARRAY getArray(Connection conn, String objType, String listType, List<?> listData) {

// 构建Oracle数组并返回

}

3、注意事项

避免直接使用大List的IN查询,优先分组或改用其他批量操作(如批量插入语句)。 ‌‌

存储过程传参需确保Java对象与Oracle类型匹配(如NVARCHAR2对应String)。 ‌‌

相关推荐
侠客行031712 小时前
Mybatis连接池实现及池化模式
java·mybatis·源码阅读
蛇皮划水怪12 小时前
深入浅出LangChain4J
java·langchain·llm
老毛肚13 小时前
MyBatis体系结构与工作原理 上篇
java·mybatis
风流倜傥唐伯虎14 小时前
Spring Boot Jar包生产级启停脚本
java·运维·spring boot
Yvonne爱编码14 小时前
JAVA数据结构 DAY6-栈和队列
java·开发语言·数据结构·python
Re.不晚14 小时前
JAVA进阶之路——无奖问答挑战1
java·开发语言
你这个代码我看不懂14 小时前
@ConditionalOnProperty不直接使用松绑定规则
java·开发语言
fuquxiaoguang14 小时前
深入浅出:使用MDC构建SpringBoot全链路请求追踪系统
java·spring boot·后端·调用链分析
琹箐14 小时前
最大堆和最小堆 实现思路
java·开发语言·算法
__WanG15 小时前
JavaTuples 库分析
java