ORA-01795: 列表中的最大表达式数为 1000 错误代码解决

手册/FAQ (666) 2016-05-05 08:57:09

 

解决的方法是拆分列表。

 

需求是提供了:号单文件,必须按号单文件查询,如果是表查询,当然可以采用join关联等实现。

 

为了把几千个号单拆分成100个为一组,写了个Java方法,进行sql语句的处理。

 

 

  1. /** 
  2.      *  Example: 
  3.      *  List sqhlist=[aa,bb,cc,dd,ee,ff,gg] ; 
  4.      *  Test.getSqlStrByList(sqhList,3,"SHENQINGH")=  
  5.      *  "SHENQING IN ('aa','bb','cc') OR SHENQINGH IN ('dd','ee','ff') OR SHENQINGH IN ('gg')" 
  6.      *  
  7.      *  把超过1000的申请号集合拆分成数量splitNum的多组sql的in 集合。 
  8.      * @param sqhList 申请号的List 
  9.      * @param splitNum 拆分的间隔数目,例如: 1000 
  10.      * @param columnName SQL中引用的字段名例如: Z.SHENQINGH  
  11.      * @return 
  12.      */  
  13.     public String getSqlStrByList(List sqhList, int splitNum,String columnName) {  
  14.         if(splitNum>1000) //因为<a href="http://lib.csdn.net/base/14" class='replace_word' title="MySQL知识库" target='_blank' style='color:#df3434; font-weight:bold;'>数据库</a>的列表sql限制,不能超过1000.  
  15.             return null;  
  16.         StringBuffer sql = new StringBuffer("");  
  17.         if (sqhList != null) {  
  18.             sql.append(" ").append(columnName).append (" IN ( ");  
  19.             for (int i = 0; i < sqhList.size(); i++) {  
  20.                 sql.append("'").append(sqhList.get(i) + "',");  
  21.                 if ((i + 1) % splitNum == 0 && (i + 1) < sqhList.size()) {  
  22.                     sql.deleteCharAt(sql.length() - 1);  
  23.                     sql.append(" ) OR ").append(columnName).append (" IN (");  
  24.                 }  
  25.             }  
  26.             sql.deleteCharAt(sql.length() - 1);  
  27.             sql.append(" )");  
  28.         }  
  29.         return sql.toString();  
  30.     }  
  31.       
  32.     /** 
  33.      * 把超过1000的申请号数组拆分成数量splitNum的多组sql的in 集合。 
  34.      * @param sqhArrays 申请号的数组 
  35.      * @param splitNum 拆分的间隔数目,例如: 1000 
  36.      * @param columnName SQL中引用的字段名例如: Z.SHENQINGH 
  37.      * @return 
  38.      */  
  39.     public String getSqlStrByArrays(String[] sqhArrays, int splitNum,String columnName){  
  40.         return getSqlStrByList(Arrays.asList(sqhArrays),splitNum,columnName);  
  41.     }  

 

THE END