SqlKit工具类

package com.trendy.fw.common.db;

import java.sql.Timestamp;
import java.text.SimpleDateFormat;
import java.util.Date;
import java.util.List;
import java.util.Set;
import java.util.regex.Matcher;
import java.util.regex.Pattern;

import com.trendy.fw.common.util.DateKit;

public class SqlKit {
	private static SimpleDateFormat SIMPLE_DATE_FORMAT = new SimpleDateFormat(DateKit.DEFAULT_DATE_TIME_FORMAT);

	/**
	 * 拼接SQL语法的字段字符串值
	 * 
	 * @param value
	 *            -- 数据
	 * @return -- SQL片段字符串
	 */
	private static String fieldValue(String value) {
		if (null == value) {
			return "''";
		}
		String v = value.trim();
		int vs = v.length();
		StringBuilder sb = new StringBuilder();
		char c = 0;
		sb.append('\'');
		for (int i = 0; i < vs; i++) {
			c = v.charAt(i);
			// 防止sql注入处理,替换'为'',替换\为\\
			if ('\'' == c) {
				sb.append('\'');
				sb.append('\'');
			} else if ('\\' == c) {
				sb.append('\\');
				sb.append('\\');
			} else {
				sb.append(c);
			}
		}
		sb.append('\'');
		return sb.toString();
	}

	/**
	 * 拼接SQL语法的字段字符串值,默认日期格式为:yyyy-MM-dd HH:mm:ss
	 * 
	 * @param value
	 *            -- 数据
	 * @return -- SQL片段字符串
	 */
	private static String fieldValue(Date value) {
		return "'" + SIMPLE_DATE_FORMAT.format(value) + "'";
	}

	/**
	 * 拼接SQL语法的字段字符串值
	 * 
	 * @param value
	 *            -- 数据
	 * @return -- SQL片段字符串
	 */
	private static String fieldValue(Timestamp value) {
		return "'" + value + "'";
	}

	/**
	 * 拼接SQL语法的字段字符串值
	 * 
	 * @param value
	 *            -- 数据
	 * @return -- SQL片段字符串,如果value为null,返回字符串:''
	 */
	public static String fieldValue(Object value) {
		if (null == value) {
			return "''";
		} else if (value instanceof String) {
			return fieldValue((String) value);
		} else if (value instanceof Date) {
			return fieldValue((Date) value);
		} else if (value instanceof Timestamp) {
			return fieldValue((Timestamp) value);
		} else if (value instanceof Integer || value instanceof Long || value instanceof Short
				|| value instanceof Float || value instanceof Double) {
			// 基本数字类型
			return fieldValuePrimitive(value);
		} else if (value instanceof List) {
			return fieldValueArray(((List) value).toArray());
		} else if (value instanceof Set) {
			return fieldValueArray(((Set) value).toArray());
		} else if (value.getClass().isArray()) {
			// 数组类型,(基本数据类型没法进行autoboxing,需要进行额外处理)
			Class ct = value.getClass().getComponentType();
			if (ct == String.class) {
				return fieldValueArray(String[].class.cast(value));
			} else if (ct == int.class) {
				return fieldValueArray(boxedPrimitiveArray((int[]) value));
			} else if (ct == long.class) {
				return fieldValueArray(boxedPrimitiveArray((long[]) value));
			} else if (ct == short.class) {
				return fieldValueArray(boxedPrimitiveArray((short[]) value));
			} else if (ct == float.class) {
				return fieldValueArray(boxedPrimitiveArray((float[]) value));
			} else if (ct == double.class) {
				return fieldValueArray(boxedPrimitiveArray((double[]) value));
			}
			// 默认,转成Object对象数组
			return fieldValueArray((Object[]) value);
		} else {
			return "'" + value.toString() + "'";
		}
	}

	/**
	 * 拼接SQL语法的字段字符串值,适用于基本数据类型
	 * 
	 * @param value
	 * @return
	 */
	private static <T> String fieldValuePrimitive(T value) {
		return value.toString();
	}

	/**
	 * 拼接SQL语法的字段字符串值,适用于数组类型
	 * 
	 * @param value
	 * @return
	 */
	private static <T> String fieldValueArray(T[] value) {
		if (null == value) {
			return "''";
		}
		StringBuilder sql = new StringBuilder();
		for (int i = 0; i < value.length; i++) {
			sql.append(fieldValue(value[i]));
			if (i < value.length - 1) {
				sql.append(",");
			}
		}
		return sql.toString();
	}

	/**
	 * 将int数组转换成Integer数组
	 * 
	 * @param array
	 * @return
	 */
	private static Integer[] boxedPrimitiveArray(int[] array) {
		Integer[] result = new Integer[array.length];
		for (int i = 0; i < array.length; i++)
			result[i] = array[i];
		return result;
	}

	/**
	 * 将short数组转换成Short数组
	 * 
	 * @param array
	 * @return
	 */
	private static Short[] boxedPrimitiveArray(short[] array) {
		Short[] result = new Short[array.length];
		for (int i = 0; i < array.length; i++)
			result[i] = array[i];
		return result;
	}

	/**
	 * 将long数组转换成Long数组
	 * 
	 * @param array
	 * @return
	 */
	private static Long[] boxedPrimitiveArray(long[] array) {
		Long[] result = new Long[array.length];
		for (int i = 0; i < array.length; i++)
			result[i] = array[i];
		return result;
	}

	/**
	 * 将float数组转换成Float数组
	 * 
	 * @param array
	 * @return
	 */
	private static Float[] boxedPrimitiveArray(float[] array) {
		Float[] result = new Float[array.length];
		for (int i = 0; i < array.length; i++)
			result[i] = array[i];
		return result;
	}

	/**
	 * 将double数组转换成Double数组
	 * 
	 * @param array
	 * @return
	 */
	private static Double[] boxedPrimitiveArray(double[] array) {
		Double[] result = new Double[array.length];
		for (int i = 0; i < array.length; i++)
			result[i] = array[i];
		return result;
	}

	public static String parseCountSql(String sql) {
//		Pattern pattern = Pattern.compile("(?<=select).*?(?=from)",Pattern.CASE_INSENSITIVE);
//		sql = sql.replace(matcher.group(0), " count(1) ");
		
		Pattern pattern = Pattern.compile("select .*? from", Pattern.CASE_INSENSITIVE);
		Matcher matcher = pattern.matcher(sql);
		if (matcher.find()) {
			Pattern groupPattern = Pattern.compile("(?=sum|avg|count|distinct|max|min|union)", Pattern.CASE_INSENSITIVE);
			Matcher groupMatcher = groupPattern.matcher(sql);
			if (groupMatcher.find()) {
				//group by 分组的 sql,保留嵌套方法
				sql = "select count(1) from (" + sql + ") t";
			}else{
				//普通sql,替换原有字段
				sql = sql.replace(matcher.group(0), "select count(1) from ");
			}
		}
		return sql;
	}
	
//	public static String parseCountSql(String sql) {
//		sql = sql.toLowerCase();
//		
//		int iFromIndex = sql.indexOf("from");
//		sql = sql.replace(sql.substring(0,iFromIndex), "select count(1) ");
//		System.out.println(sql);
//		
//		return sql;
//	}

	public static String parseCondList2String(List<String> condList, boolean isNeedWhere) {
		StringBuilder sb = new StringBuilder();
		if (condList.size() > 0) {
			if (isNeedWhere) {
				sb.append(" where ");
			}
			for (int i = 0; i < condList.size(); i++) {
				String cond = condList.get(i);
				if (i > 0) {
					sb.append(" and ");
				}
				sb.append(cond);
			}
		}
		return sb.toString();
	}

	public static String parseInQuery(int count) {
		StringBuffer sb = new StringBuffer();
		for (int i = 0; i < count; i++) {
			if (i > 0) {
				sb.append(", ");
			}
			sb.append("?");
		}
		return sb.toString();
	}
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
package com.hexiang.utils; /** * SQLUtils utils = new SQLUtils(User.class); utils.setWhereStr("", "id", "=", 100).setWhereStr("and", "name", " ", "is null").setWhereStr("and", "date", ">=", new Date()); utils.setOrderByStr("id", "desc").setOrderByStr("name", "asc"); System.out.println(utils.buildSelectSQL()); System.out.println(utils.buildCountSQL()); */ import java.sql.Timestamp; import java.text.SimpleDateFormat; import java.util.Date; import java.util.LinkedHashMap; import java.util.LinkedList; import java.util.List; import java.util.Map; public class SqlUtils { private String beanName; private String beanShortName; private Map propertyMap; private List conditionList; private List relationList; private Map orderByMap; public SqlUtils(Class instance) { this.setBeanName(instance.getSimpleName()); this.setBeanShortName(Character.toLowerCase(this.getBeanName() .charAt(0)) + ""); init(); } public SqlUtils() { init(); } void init(){ propertyMap = new LinkedHashMap(); conditionList = new LinkedList(); relationList = new LinkedList(); orderByMap = new LinkedHashMap(); } /** * 添加查询条件 * * @param relation * 关联 "and","or"等 * @param property * 查询的对象属性 * @param condition * 查询的条件,关系符 * @param value * 查询的值 */ public SqlUtils setWhereStr(String relation, String property, String condition, Object value) { if(value != null){ relationList.add(relation); propertyMap.put(property, value); conditionList.add(condition); } return this; } private String buildWhereStr() { StringBuffer buffer = new StringBuffer(); if (!propertyMap.isEmpty() && propertyMap.size() > 0) { buffer.append("WHERE 1 = 1 "); int index = 0; for (String property : propertyMap.keySet()) { if (property != null && !property.equals("")) { buffer.append(r
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值