简单SQL查询组件(整理),有需要的朋友可以参考下。


相信大家在业务非常复杂,客户要求非常头疼的情况下写的查询SQL语句也是一种非常痛苦事了,还好我跟老师做的项目中要求不是很多,差不多就5,6个样子,但是就是这5,6个样子也把我累得像狗。刚开始的时候想到的方案是写if/else语句,条件少点还过得去,但是条件多了就不行。因此,这次介绍一个简单查询组件的编写(所编写的HQL语句应用于hibernate中,当然你可以改一下用到sql语句中)。

作为一条完整的HQL语句,应该包括 SELECT [condition] FROM ClassName alias where [....]ORDER BY [....].那么我们可以将HQL语句简单分解为三个部分fromClause,whereClause和orderClause三个组成部分。我们需要做的是就是拼接fromClause+whereClause+orderClause.好了,上代码:

 

/**
 * 简单查询组件
 * @author Administrator
 */
public class QueryHelper {

	//form子句
	private StringBuffer fromClause = new StringBuffer(); 
	//where子句
	private StringBuffer whereClause = new StringBuffer();
	//oderby子句
	private StringBuffer orderByClause = new StringBuffer() ;
	//获取参数代码
	private List<Object> listObject = new ArrayList<Object>() ;
	
	/**
	 * 初始化,构建from字句,注意空格!!!
	 * @param clazz
	 * @param alias
	 */
	public QueryHelper(Class<?> clazz , String alias){
		fromClause.append(" FROM  " + clazz.getSimpleName()+"   "+alias) ;
	}
	
	/**
	 * 添加where字句,注意空格!!
	 * @param condition
	 * @param paramters
	 */
	public QueryHelper  addWhereCondition(String condition , Object...paramters){
		if(whereClause.toString().length() == 0){
			whereClause.append("	WHERE  " + condition) ;
		}else{
			whereClause.append("  AND  " +condition);
		}
		//添加参数
		for(Object obj : paramters){
			listObject.add(obj);
		}
		return this ;
	}
	
	public QueryHelper addWhereCondition(boolean isWhere , String  condition , Object...paramters){
		if(isWhere)
		   addWhereCondition(condition,paramters);
		return this ;
	}
	
	/**
	 *添加orderby参数,注意空格
	 * @param orderBy
	 * @param order true为升序 false为降序
	 */
	public QueryHelper addOrderByCondition(String orderBy , boolean order){
		if(orderByClause.toString().length() == 0){
			orderByClause.append(" ORDER BY  "+orderBy + (order ? "  ASC  " : "  DESC  ")) ;
		}else{
			orderByClause.append(" , " + orderBy+ (order ? "  ASC  " : "  DESC  ")) ;
		}
		return this ;
	}
	//计算记录的条数,这是基本上是需求中要求最多的。
	public String getTotalCount(){
		return "SELECT  COUNT(*)  " + fromClause + whereClause  ;
	}
	
	public QueryHelper addOrderByCondition(boolean isOrder , String orderBy , boolean order){
		if(isOrder)
			addOrderByCondition(orderBy,order);
		return this ;
	}

	public List<Object> getListObject() {
		return listObject;
	}

	public String getQuery(){
		return fromClause.toString() + whereClause.toString() + orderByClause.toString() ;
	}
	
}
	
以上就是分页代码了,好了,怎么使用呢,来看下面的例子:

 

假设存在一个User用户,需要查找一个姓zhang的,成绩(抱歉我还是学生,只能这么幼稚啊)大于90分的,按照id升序,然后name降序的查询语句:

 

@Test
	public void testUser(){
		QueryHelper query = new QueryHelper(User.class ,"user") ;
		query.addWhereCondition("user.name like  ?", "'%zhang%'");
		//前面的Boolean变量是判断是否加入条件,这只是模拟一般性,
		//因为实际项目中我们不知道该条件是否存在
		query.addWhereCondition((2 > 1), "user.grade > ?", 90);
		query.addOrderByCondition("user.id", true) ;
		//同理前一个Boolean是为了增加一般性,
		//实际项目中要判断是否存在该条件
		query.addOrderByCondition(true, "user.name", false) ;
		
		//HQL一般查询语句
		System.out.println(query.getQuery());
		//HQL满足条件总数
		System.out.println(query.getTotalCount());
		//HQL需要参数
		System.out.println(query.getListObject());
		
	}

那么输出结果可以看到:

 

 

FROM  User   user	WHERE  user.name like  ?  AND  user.grade > ? ORDER BY  user.id  ASC   , user.name  DESC  
SELECT  COUNT(*)   FROM  User   user	WHERE  user.name like  ?  AND  user.grade > ?
['%zhang%', 90]
呵呵,我们非常不爽的代码就完全通过工具实现了。这样就可以少点抱怨多用心学习了啊。

 

ps:这可能是对于单个项目定制的,你完全可以通过自己想象的空间,去创建更多优秀的代码的。。。