zoukankan      html  css  js  c++  java
  • Java Sql IN 条件拼接工具类,SqlUtils工具类

    ================================

    ©Copyright 蕃薯耀 2020-01-07

    https://www.cnblogs.com/fanshuyao/

    import java.util.ArrayList;
    import java.util.List;
    
    import org.apache.commons.lang.StringUtils;
    
    public class SqlUtils {
    
        /**
         * 
         * @param params List<Object>,sql执行的?参数List 
         * @param sqlBuffer StringBuffer
         * @param column String,表字段,当column=user_name,生成如下:user_name in (?,?)
         * @param values Object[],问号(?)的数组值,
         */
        public static void setInSql(List<Object> params, StringBuffer sqlBuffer, String column, Object[] values) {
            sqlBuffer.append(" ").append("and").append(" ").append(column).append(" ").append("in (");
            for (Object obj : values) {
                if(obj != null){
                    sqlBuffer.append(" ").append("?,");
                    params.add(obj);
                }
            }
            sqlBuffer.delete(sqlBuffer.length() - 1, sqlBuffer.length());
            sqlBuffer.append(" ").append(")");
        }
        
        /**
         * 
         * @param params sql执行的?参数List List<Object>
         * @param sqlBuffer StringBuffer
         * @param column 表字段,当column=user_name,生成如下:user_name in (?,?)
         * @param valuesString String,以英文逗号(,)分隔的字符串
         */
        public static void setInSql(List<Object> params, StringBuffer sqlBuffer, String column, String valuesString) {
            String[] values = valuesString.split(",");
            setInSql(params, sqlBuffer, column, values);
        }
        
        
        /**
         * 字符串参数转成整型数组
         * @param valuesString
         * @return
         */
        public static Integer[] getIntegerValue(String valuesString){
            List<Integer> integerValues = new ArrayList<Integer>();
            if(!StringUtils.isBlank(valuesString)){
                if(valuesString.indexOf(",") > -1){
                    String[] values = valuesString.split(",");
                    for (String value : values) {
                        if(!StringUtils.isBlank(value)){
                            integerValues.add(Integer.valueOf(value.trim()));
                        }
                    }
                }else{
                    integerValues.add(Integer.valueOf(valuesString.trim()));
                }
                return integerValues.toArray(new Integer[integerValues.size()]);
            }
            return null;
        }
        
        /**
         * 
         * @param sqlBuffer StringBuffer
         * @param column String,表字段,当column=user_name,生成如下:user_id in (1, 2)
         * @param values Integer[],数组值
         */
        public static void getInSql(StringBuffer sqlBuffer, String column, Integer[] values) {
            if(values == null || values.length < 1){
                throw new RuntimeException("参数值不能为空");
            }
            sqlBuffer.append(" ").append("and").append(" ").append(column).append(" ").append("in (");
            for (Integer value : values) {
                if(value != null){
                    sqlBuffer.append(" ").append(value).append(",");
                }
            }
            sqlBuffer.delete(sqlBuffer.length() - 1, sqlBuffer.length());
            sqlBuffer.append(" ").append(")");
        }
        
        
        /**
         * 
         * @param sqlBuffer StringBuffer
         * @param column String,表字段,当column=user_name,生成如下:user_name in ('a','b')
         * @param values String[],数组值
         */
        public static void getInSql(StringBuffer sqlBuffer, String column, String[] values) {
            if(values == null || values.length < 1){
                throw new RuntimeException("参数值不能为空");
            }
            sqlBuffer.append(" ").append("and").append(" ").append(column).append(" ").append("in (");
            for (String value : values) {
                if(value != null){
                    sqlBuffer.append(" '").append(value).append("',");
                }
            }
            sqlBuffer.delete(sqlBuffer.length() - 1, sqlBuffer.length());
            sqlBuffer.append(" ").append(")");
        }
        
        
        public static void main(String[] args) {
            /*
            String[] values = "a".split(",");
            System.out.println(JsonUtils.toJson(values));
            
            String[] values2 = "a,b,c".split(",");
            System.out.println(JsonUtils.toJson(values2));
            */
            
            /*
            StringBuffer sqlBuffer = new StringBuffer("");
            getInSql(sqlBuffer, "id", new Integer[]{1,2,3});
            System.out.println(sqlBuffer.toString());
            getInSql(sqlBuffer, "name", new String[]{"a", "b", "cccc"});
            System.out.println(sqlBuffer.toString());
            */
            
            Integer[] values = getIntegerValue("1 ,2,4  ,5,,7");
            for (Integer integer : values) {
                System.out.println(integer);
            }
        }
        
    }

    (如果你觉得文章对你有帮助,欢迎捐赠,^_^,谢谢!) 

    ================================

    ©Copyright 蕃薯耀 2020-01-07

    https://www.cnblogs.com/fanshuyao/

  • 相关阅读:
    grep: Linux基础命令及用法 -- grep
    [功能集锦] 003
    [功能集锦] 002
    [mysql相关集锦] 001
    [eclipse中使用Git插件] 008
    [eclipse相关] 001
    [代码优化集锦]
    [功能集锦] 001
    [java基础] 002
    [java基础] 001
  • 原文地址:https://www.cnblogs.com/fanshuyao/p/12159766.html
Copyright © 2011-2022 走看看