最近遇到一个oracle错误,之前并没有遇到过,并不是select in超过1000个导致的,通过网上资料说是oracle版本导致,也有的说是oracle SQL过长导致。

然后通过自己实践应该说是oracle SQL过长导致,看了一下SQL并不是很长,主要还是select in,因为主键换成uuid之后,来几百个uuid的数据,select in就导致SQL过长报错,我觉得网上所说的换oracle版本,也有可能是oracle版本对SQL过长支持不同。不过我还是通过改写业务SQL解决问题的。项目中也不可能随便就换oracle版本。

原来的代码,主要是select in 然后itemCode就是用;分隔的一大串的主键字符串,然后又换成uuid的了,所以导致sql过长

/**
* 获取信息模板
* @return
*/
private List<ApprSmsItemSettingVo> getSettingTemplate(String itemCode)
throws SQLException {
PreparedStatement pst = null;
StringBuffer sb = new StringBuffer();
sb.append("select a.itemCode, ");
sb.append("a.type, ");
sb.append("b.warn_days, ");
sb.append("c.proj_name, ");
sb.append("c.cust_name, ");
sb.append("a.is_send ");
sb.append("from t_item_setting a ");
sb.append("left join t_itm_define b on b.itemCode= a.itemCode ");
sb.append("b.itemCode where a.is_send in (1) and a.itemCode in (?) ");
pst = this.connection.prepareStatement(sb.toString()); pst.setString(1, itemCode);
ResultSet rs = pst.executeQuery();
List<ItemSettingVo> list = new ArrayList<ItemSettingVo>();
while(rs.next()){
ItemSettingVo vo = new ItemSettingVo();
vo.setItemCode(rs.getString("itemCode"));
vo.setType(rs.getLong("type"));
vo.setSmsTemplet(rs.getString("sms_templet"));
vo.setWarnDays(rs.getLong("warn_days"));
vo.setIsSend(rs.getLong("is_send"));
list.add(vo);
}
rs.close();
pst.close();
return list;
}

解决方法:用分组遍历再拼装为一个List的方法,这样就可以避免select in,然后in里面又是一大堆uuid的数据,然后就导致sql执行过长报错了

/**
* 获取信息模板
* fixed #ORA-01460: 转换请求无法实施或不合理
* ps:主键换成uuid之后,原来的方法会出现ORA-01460出错,sql太长导致
* @param itemCode
* @return
* @throws Exception
*/
public List<ItemSettingVo> getItemSettingVos(String itemCode)throws Exception{
List<ItemSettingVo> templateList = new ArrayList<ItemSettingVo>();
StringBuffer itmStr = new StringBuffer();
//XXX fixed Exception#ORA-01460: 转换请求无法实施或不合理 modify on 20190109
//暂时用分组遍历再拼装为一个List的方法,原来的方法放在getSettingTemplate
if(StringUtils.isNotBlank(itemCode)){
//itemCode = itemCode.replace("(", "").replace(")", "");
String[] itemCodeArr = StringUtils.split(itemCode,",");
int len = itemCodeArr.length;
if (len < 100) {//没超过100个事项编码的情况,按照原来的方法
templateList = this.getSettingTemplate(itemCode);
} else {//超过100个事项编码的情况,分组遍历,然后再拼装list,避免Exception#ORA-01460: 转换请求无法实施或不合理
List<Collection<String>> itms =CollectionUtils.splitCollection(Arrays.asList(itemCodeArr), 100);
for (Collection<String> colle: itms) {
for (String str : colle) {
itmStr.append("'").append(str).append("'").append(",");
}
itemCode = itmStr.toString().substring(0, itmStr.toString().length()-1);
templateList.addAll(this.getSmsSettingTemplate(itemCode));
itmStr.delete(0, itmStr.length());
}
System.out.println("get apprTemplateList:{}"+templateList.size());
}
} return templateList;
}

集合拆分工具类,工具类复制公司同事写的代码

import java.util.ArrayList;
import java.util.Collection;
import java.util.List;
public class CollectionUtils {
public static List<Collection<String>> splitCollection(Collection<String>values , int size) {
List<Collection<String>> result = new ArrayList<Collection<String>>();
if(values.size() <= size ){
result.add(values);
}else{
int count =0;
Collection<String> subCollection= null;
for(String s:c){
if(subCollection == null){
subColletion = new ArrayList<String>();
result.add(subColletion);
}
subCollection.add(s);
count++;
if(count == size){
count =0;
subCollectiion = null;
}
}
}
}
}

fixed Oracle SQL报错 #ORA-01460: 转换请求无法实施或不合理的更多相关文章

  1. Oracle 12c报错:ORA-01078和LRM-00109的解决办法

    Oracle 12c报错:ORA-01078和LRM-00109的解决办法 2017-12-17 10:25:30 lemon_love1 阅读数 4336  收藏 更多 分类专栏: oracle   ...

  2. Oracle启动报错ORA-27102解决

    环境:RHEL5.5 + Oracle 10.2.0.4 此错误一般是因为数据库的初始化参数文件的内存设置不当导致.本例是因为操作系统参数设置问题导致. 当前现象:Oracle启动报错ORA-2710 ...

  3. oracle之报错:ORA-00054: 资源正忙,要求指定 NOWAIT

    oracle之报错:ORA-00054: 资源正忙,要求指定 NOWAIT 问题如下: SQL> conn scott/tiger@vm_database Connected to Oracle ...

  4. TNS-12532: TNS:invalid argument,Oracle的报错信息太让人无语

    TNS-12532: TNS:invalid argument,Oracle的报错信息太让人无语 现象: Tnsping报错: [oracle@unicomGZ01 admin]$ ../../bin ...

  5. oracle 12c 报错 ora-03137 来自客户机的格式错误的TTC包被拒绝

    昨天下午,实施报了一个oracle的报错ora-03137 说是数据库在11g时没有问题,升级到12c 时,就报错了. 本地调试,看到执行完sql后,报异常,如下: 把SqL在12c的数据库执行一下, ...

  6. oracle+mybatis报错:BindingException("Invalid bound statement (not found): ")

    oracle+mybatis报错:BindingException("Invalid bound statement (not found): ") 从mysql转到oracle数 ...

  7. 利用sql报错帮助进行sql注入

    我们可以利用sql报错帮助进行sql注入,这里以sql server 为例: sql查询时,若用group by子句时,该子句中的字段必须跟select 条件中的字段(非聚合函数)完全匹配,如果是se ...

  8. windows,oracle,dg报错:ORA-12528,ORA-12154,ORA-10456 ,PING[ARC1]: Heartbeat failed to connect to standby 'orclbk'. Error is 12154

    windows,oracle,dg报错:ORA-12528,ORA-12154,ORA-10456 最近有需求在windows的2台oracle服务器上搭建dg,在过程中遇到了一些错误,跟在linux ...

  9. 数据库执行sql报错Got a packet bigger than 'max_allowed_packet' bytes及重启mysql

    准备在mysql上使用数据库A,但mysql5经过重装后,上面的数据库已丢失,只得通过之前备份的A.sql重新生成数据库A. 1.执行sql报错 在执行A.sql的过程中,出现如下错误:Got a p ...

随机推荐

  1. centos 7 常用工具篇

    1.vmstat监控linux整体性能工具如查看命令:vmstat 1 4 2.用netstat查看网络连接,接口等信息如:netstat -an 3.dig  或者nslookup 跟踪yum解析过 ...

  2. composer require aliyuncs/oss-sdk-php

    composer require aliyuncs/oss-sdk-php composer install require_once __DIR__ . '/vendor/autoload.php' ...

  3. node.js 使用 superagent 与 cheerio 完成简单爬虫

    目标 建立一个 lesson3 项目,在其中编写代码. 当在浏览器中访问 http://localhost:3000/ 时,输出 CNode(https://cnodejs.org/ ) 社区首页的所 ...

  4. Effective C++ 笔记:条款 33 避免继承导致的名称遮掩

    Avoid hiding inherited names 作用域(scopes)所带来的名称二义性,c++编译器会寻找指涉(refer to)的对象并实现名称遮掩规则(name-hiding rule ...

  5. Codeforces Round #555 (Div. 3) E. Minimum Array

    题意:b数组可以自由排序,c[i]=(a[i]+b[i])%n. 题目中要求c数组的字典序是最小的.那么我们需要尽量满足前面的c[i],才能使字典序最小. 我们知道a[i]和b[i]都是[0,n-1] ...

  6. java根据图片创建日期,或最后修改日期重命名

    import java.io.BufferedReader; import java.io.File; import java.io.FileNotFoundException; import jav ...

  7. tp5 数据库

    连接数据库: 在config下面的database.php里. 查找数据: halt(Db::name('studys')->column('name','age')); 也可以用find fi ...

  8. 使用VS+OpenCV调用深度学习模型

    最近项目有个任务,要在windows环境下用VS+OpenCV实现caffe模型的调用,于是在网上找了几个相关的博客跑了几个demo练练手.这些博客写得都很详细,但是有些细节由于版本更新的问题,配置的 ...

  9. C#语法快速热身

    if选择结构: 简单:if结构 单分子:If-else结构 多重:f-else-if结构 嵌套:if结构 语法: If(条件1){ If(条件2) }else{ } }else{ } Switch结构 ...

  10. Eclipse下用NDK编译生成so文件

      我们在安装环境的时候安装了NDK,可以在eclipse下直接生成so文件.NDK的压缩包里面自带了一些sample工程,NDK的文件直接解压到某个目录下即可. 第一次生成so文件的时候,我们先使用 ...