简单SQL查询组件(整理)

来源:互联网 发布:淘宝法莎莉雅手办 编辑:程序博客网 时间:2024/06/05 08:26

相信大家在业务非常复杂,客户要求非常头疼的情况下写的查询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降序的查询语句:

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

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


0 0
原创粉丝点击