java代码处理Oracle中IN参数超过1000

应用场景:代码中的有些逻辑SQL不是通过mapper处理的,而是通过逻辑拼接的


import java.util.ArrayList;

class ParamerOfInToLarge {
    
    

    public static void main(String[] args) {
    
    
       // String str = "1,2,3,4,5,6,7,8,9";
       // String str = "11";
        String str = "1,2,3,4,5,6,7,8,9,10,11,12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, 26, 27, 28, 29, 30, 31, 32, 33, 34, 35, 36, 37, 38, 39, 40, 41, 42, 43, 44, 45, 46, 47, 48, 49, 50, 51, 52, 53, 54, 55, 56, 57, 58, 59, 60, 61, 62, 63, 64, 65, 66, 67, 68, 69, 70, 71, 72, 73, 74, 75, 76, 77, 78, 79, 80, 81,  83,  84,  85, 86, 87,  88,  89,90, 91, 92, 93, 94,95,96,97,98,99,100,1,2,3,4,5,6,7,8,9,10,11,12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, 26, 27, 28, 29, 30, 31, 32, 33, 34, 35, 36, 37, 38, 39, 40, 41, 42, 43, 44, 45, 46, 47, 48, 49, 50, 51, 52, 53, 54, 55, 56, 57, 58, 59, 60, 61, 62, 63, 64, 65, 66, 67, 68, 69, 70, 71, 72, 73, 74, 75, 76, 77, 78, 79, 80, 81,  83,  84,  85, 86, 87,  88,  89,90, 91, 92, 93, 94,95,96,97,98,99,100,1,2,3,4,5,6,7,8,9,10,11,12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, 26, 27, 28, 29, 30, 31, 32, 33, 34, 35, 36, 37, 38, 39, 40, 41, 42, 43, 44, 45, 46, 47, 48, 49, 50, 51, 52, 53, 54, 55, 56, 57, 58, 59, 60, 61, 62, 63, 64, 65, 66, 67, 68, 69, 70, 71, 72, 73, 74, 75, 76, 77, 78, 79, 80, 81,  83,  84,  85, 86, 87,  88,  89,90, 91, 92, 93, 94,95,96,97,98,99,100,1,2,3,4,5,6,7,8,9,10,11,12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, 26, 27, 28, 29, 30, 31, 32, 33, 34, 35, 36, 37, 38, 39, 40, 41, 42, 43, 44, 45, 46, 47, 48, 49, 50, 51, 52, 53, 54, 55, 56, 57, 58, 59, 60, 61, 62, 63, 64, 65, 66, 67, 68, 69, 70, 71, 72, 73, 74, 75, 76, 77, 78, 79, 80, 81,  83,  84,  85, 86, 87,  88,  89,90, 91, 92, 93, 94,95,96,97,98,99,100,1,2,3,4,5,6,7,8,9,10,11,12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, 26, 27, 28, 29, 30, 31, 32, 33, 34, 35, 36, 37, 38, 39, 40, 41, 42, 43, 44, 45, 46, 47, 48, 49, 50, 51, 52, 53, 54, 55, 56, 57, 58, 59, 60, 61, 62, 63, 64, 65, 66, 67, 68, 69, 70, 71, 72, 73, 74, 75, 76, 77, 78, 79, 80, 81,  83,  84,  85, 86, 87,  88,  89,90, 91, 92, 93, 94,95,96,97,98,99,100,1,2,3,4,5,6,7,8,9,10,11,12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, 26, 27, 28, 29, 30, 31, 32, 33, 34, 35, 36, 37, 38, 39, 40, 41, 42, 43, 44, 45, 46, 47, 48, 49, 50, 51, 52, 53, 54, 55, 56, 57, 58, 59, 60, 61, 62, 63, 64, 65, 66, 67, 68, 69, 70, 71, 72, 73, 74, 75, 76, 77, 78, 79, 80, 81,  83,  84,  85, 86, 87,  88,  89,90, 91, 92, 93, 94,95,96,97,98,99,100,1,2,3,4,5,6,7,8,9,10,11,12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, 26, 27, 28, 29, 30, 31, 32, 33, 34, 35, 36, 37, 38, 39, 40, 41, 42, 43, 44, 45, 46, 47, 48, 49, 50, 51, 52, 53, 54, 55, 56, 57, 58, 59, 60, 61, 62, 63, 64, 65, 66, 67, 68, 69, 70, 71, 72, 73, 74, 75, 76, 77, 78, 79, 80, 81,  83,  84,  85, 86, 87,  88,  89,90, 91, 92, 93, 94,95,96,97,98,99,100,1,2,3,4,5,6,7,8,9,10,11,12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, 26, 27, 28, 29, 30, 31, 32, 33, 34, 35, 36, 37, 38, 39, 40, 41, 42, 43, 44, 45, 46, 47, 48, 49, 50, 51, 52, 53, 54, 55, 56, 57, 58, 59, 60, 61, 62, 63, 64, 65, 66, 67, 68, 69, 70, 71, 72, 73, 74, 75, 76, 77, 78, 79, 80, 81,  83,  84,  85, 86, 87,  88,  89,90, 91, 92, 93, 94,95,96,97,98,99,100,1,2,3,4,5,6,7,8,9,10,11,12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, 26, 27, 28, 29, 30, 31, 32, 33, 34, 35, 36, 37, 38, 39, 40, 41, 42, 43, 44, 45, 46, 47, 48, 49, 50, 51, 52, 53, 54, 55, 56, 57, 58, 59, 60, 61, 62, 63, 64, 65, 66, 67, 68, 69, 70, 71, 72, 73, 74, 75, 76, 77, 78, 79, 80, 81,  83,  84,  85, 86, 87,  88,  89,90, 91, 92, 93, 94,95,96,97,98,99,100,1,2,3,4,5,6,7,8,9,10,11,12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, 26, 27, 28, 29, 30, 31, 32, 33, 34, 35, 36, 37, 38, 39, 40, 41, 42, 43, 44, 45, 46, 47, 48, 49, 50, 51, 52, 53, 54, 55, 56, 57, 58, 59, 60, 61, 62, 63, 64, 65, 66, 67, 68, 69, 70, 71, 72, 73, 74, 75, 76, 77, 78, 79, 80, 81,  83,  84,  85, 86, 87,  88,  89,90, 91, 92, 93, 94,95,96,97,98,99,100,1,2,3,4,5,6,7,8,9,10,11,12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, 26, 27, 28, 29, 30, 31, 32, 33, 34, 35, 36, 37, 38, 39, 40, 41, 42, 43, 44, 45, 46, 47, 48, 49, 50, 51, 52, 53, 54, 55, 56, 57, 58, 59, 60, 61, 62, 63, 64, 65, 66, 67, 68, 69, 70, 71, 72, 73, 74, 75, 76, 77, 78, 79, 80, 81,  83,  84,  85, 86, 87,  88,  89,90, 91, 92, 93, 94,95,96,97,98,99,100,1,2,3,4,5,6,7,8,9,10,11,12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, 26, 27, 28, 29, 30, 31, 32, 33, 34, 35, 36, 37, 38, 39, 40, 41, 42, 43, 44, 45, 46, 47, 48, 49, 50, 51, 52, 53, 54, 55, 56, 57, 58, 59, 60, 61, 62, 63, 64, 65, 66, 67, 68, 69, 70, 71, 72, 73, 74, 75, 76, 77, 78, 79, 80, 81,  83,  84,  85, 86, 87,  88,  89,90, 91, 92, 93, 94,95,96,97,98,99,100,1,2,3,4,5,6,7,8,9,10,11,12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, 26, 27, 28, 29, 30, 31, 32, 33, 34, 35, 36, 37, 38, 39, 40, 41, 42, 43, 44, 45, 46, 47, 48, 49, 50, 51, 52, 53, 54, 55, 56, 57, 58, 59, 60, 61, 62, 63, 64, 65, 66, 67, 68, 69, 70, 71, 72, 73, 74, 75, 76, 77, 78, 79, 80, 81,  83,  84,  85, 86, 87,  88,  89,90, 91, 92, 93, 94,95,96,97,98,99,100,1,2,3,4,5,6,7,8,9,10,11,12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, 26, 27, 28, 29, 30, 31, 32, 33, 34, 35, 36, 37, 38, 39, 40, 41, 42, 43, 44, 45, 46, 47, 48, 49, 50, 51, 52, 53, 54, 55, 56, 57, 58, 59, 60, 61, 62, 63, 64, 65, 66, 67, 68, 69, 70, 71, 72, 73, 74, 75, 76, 77, 78, 79, 80, 81,  83,  84,  85, 86, 87,  88,  89,90, 91, 92, 93, 94,95,96,97,98,99,100,1,2,3,4,5,6,7,8,9,10,11,12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, 26, 27, 28, 29, 30, 31, 32, 33, 34, 35, 36, 37, 38, 39, 40, 41, 42, 43, 44, 45, 46, 47, 48, 49, 50, 51, 52, 53, 54, 55, 56, 57, 58, 59, 60, 61, 62, 63, 64, 65, 66, 67, 68, 69, 70, 71, 72, 73, 74, 75, 76, 77, 78, 79, 80, 81,  83,  84,  85, 86, 87,  88,  89,90, 91, 92, 93, 94,95,96,97,98,99,100,1,2,3,4,5,6,7,8,9,10,11,12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, 26, 27, 28, 29, 30, 31, 32, 33, 34, 35, 36, 37, 38, 39, 40, 41, 42, 43, 44, 45, 46, 47, 48, 49, 50, 51, 52, 53, 54, 55, 56, 57, 58, 59, 60, 61, 62, 63, 64, 65, 66, 67, 68, 69, 70, 71, 72, 73, 74, 75, 76, 77, 78, 79, 80, 81,  83,  84,  85, 86, 87,  88,  89,90, 91, 92, 93, 94,95,96,97,98,99,100,1,2,3,4,5,6,7,8,9,10,11,12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, 26, 27, 28, 29, 30, 31, 32, 33, 34, 35, 36, 37, 38, 39, 40, 41, 42, 43, 44, 45, 46, 47, 48, 49, 50, 51, 52, 53, 54, 55, 56, 57, 58, 59, 60, 61, 62, 63, 64, 65, 66, 67, 68, 69, 70, 71, 72, 73, 74, 75, 76, 77, 78, 79, 80, 81,  83,  84,  85, 86, 87,  88,  89,90, 91, 92, 93, 94,95,96,97,98,99,100,1,2,3,4,5,6,7,8,9,10,11,12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, 26, 27, 28, 29, 30, 31, 32, 33, 34, 35, 36, 37, 38, 39, 40, 41, 42, 43, 44, 45, 46, 47, 48, 49, 50, 51, 52, 53, 54, 55, 56, 57, 58, 59, 60, 61, 62, 63, 64, 65, 66, 67, 68, 69, 70, 71, 72, 73, 74, 75, 76, 77, 78, 79, 80, 81,  83,  84,  85, 86, 87,  88,  89,90, 91, 92, 93, 94,95,96,97,98,99,100,1,2,3,4,5,6,7,8,9,10,11,12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, 26, 27, 28, 29, 30, 31, 32, 33, 34, 35, 36, 37, 38, 39, 40, 41, 42, 43, 44, 45, 46, 47, 48, 49, 50, 51, 52, 53, 54, 55, 56, 57, 58, 59, 60, 61, 62, 63, 64, 65, 66, 67, 68, 69, 70, 71, 72, 73, 74, 75, 76, 77, 78, 79, 80, 81,  83,  84,  85, 86, 87,  88,  89,90, 91, 92, 93, 94,95,96,97,98,99,100,1,2,3,4,5,6,7,8,9,10,11,12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, 26, 27, 28, 29, 30, 31, 32, 33, 34, 35, 36, 37, 38, 39, 40, 41, 42, 43, 44, 45, 46, 47, 48, 49, 50, 51, 52, 53, 54, 55, 56, 57, 58, 59, 60, 61, 62, 63, 64, 65, 66, 67, 68, 69, 70, 71, 72, 73, 74, 75, 76, 77, 78, 79, 80, 81,  83,  84,  85, 86, 87,  88,  89,90, 91, 92, 93, 94,95,96,97,98,99,100,1,2,3,4,5,6,7,8,9,10,11,12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, 26, 27, 28, 29, 30, 31, 32, 33, 34, 35, 36, 37, 38, 39, 40, 41, 42, 43, 44, 45, 46, 47, 48, 49, 50, 51, 52, 53, 54, 55, 56, 57, 58, 59, 60, 61, 62, 63, 64, 65, 66, 67, 68, 69, 70, 71, 72, 73, 74, 75, 76, 77, 78, 79, 80, 81,  83,  84,  85, 86, 87,  88,  89,90, 91, 92, 93, 94,95,96,97,98,99,100";

        String inSqlByPks = getInSqlByPks(str.split(","), 1000, "sys_user");
        System.out.println(inSqlByPks);

    }

    /**
     * @param pks in查询的条件数组
     * @param len 每个查询语句中出现的条件个数
     * @param field 查询字段
     * @return
     */
    public static String getInSqlByPks(String[]pks,int len,String field){
    
    
        StringBuffer sql=new StringBuffer("");
        if(len<=0||len>1000){
    
    
            len=1000;
        }
        if(pks.length>len){
    
    
            int count=pks.length/len;
            for(int i=0;i<=count;i++){
    
    
                String[]tempPks=subArrayFree(pks,len*i,len*(i+1));
                if(tempPks!=null&&tempPks.length>0){
    
    
                    if(i>0){
    
    
                        sql.append(" or ");
                    }
                    sql.append(field+arrayToSqlCond(tempPks,true));
                }
            }
        }else{
    
    
            sql.append(field+arrayToSqlCond(pks,true));
        }
        return sql.toString();
    }

    /**
     * @description 截取数组
     * @param arr   要截取的数组
     * @param begin 开始截取下标
     * @param end   结束截取下标
     * @return
     */
    public static String[]subArrayFree(String[]arr,int begin,int end){
    
    
        if(arr==null)
            return null;
        if(arr.length==0||(arr.length-1)<begin)
            return null;
        if(end>arr.length)
            end=arr.length;
        ArrayList<String> list=new ArrayList<String>();
        for(int i=begin;i<end; i++){
    
    
            list.add(arr[i]);
        }
        return list.toArray(new String[0]);
    }

    /**
     * 数组转换为sql查询条件
     *
     * @param arr 条件数组
     * @param isIn  是否是包含(in)或者不包含(not in)
     * @return
     */
    public static String arrayToSqlCond(String[]arr,boolean isIn){
    
    
        StringBuffer cond=new StringBuffer("");
        if(arr!=null){
    
    
            int len=arr.length;
            if(len==1){
    
    
                if(isIn){
    
    
                    cond.append(" = '");
                }else{
    
    
                    cond.append(" != '");
                }
                cond.append(arr[0]).append("'");
            }else if(len>1){
    
    
                if(isIn){
    
    
                    cond.append(" in ('");
                }else{
    
    
                    cond.append(" not in ('");
                }
                for(int i=0;i<len; i++){
    
    
                    cond.append(arr[i]);
                    if(i<len -1)
                        cond.append("','");
                }
                cond.append("')");
            }
        }
        return cond.toString();
    }
}

猜你喜欢

转载自blog.csdn.net/qq_43050077/article/details/119455976
今日推荐