动态查询:简单的说就是多种条件的查询都写在一个方法中。
有些朋友写查询拿用户来说,查名称、id、特征,一下写三个方法,如果又查名称又查特征那么还要补充方法;采用动态查询以后所有的这些查询都可以写在一个方法中,在这儿我结合一下hibernate谈一下动态查询。
第一种动态查询:自己封装sql
第二种:采用hibernate封装
1、创建一个Criteria实例
net.sf.hibernate.Criteria这个接口代表对一个特定的持久化类的查询。Session是用来制造Criteria实例的工厂。
2、缩小结果集范围
一个查询条件(Criterion)是net.sf.hibernate.expression.Criterion接口的一个实例。类net.sf.hibernate.expression.Expression定义了获得一些内置的Criterion类型。
表达式(Expressions)可以按照逻辑分组.
3、对结果排序
可以使用net.sf.hibernate.expression.Order对结果集排序.
再此只是简单的介绍了下hibernate的动态查询的用法,自己封装要很仔细,如果采用hibernate封装需要对hibernate有一定了解,有兴趣的朋友可以去看看hibernate中的关联,以及示例查询等
有些朋友写查询拿用户来说,查名称、id、特征,一下写三个方法,如果又查名称又查特征那么还要补充方法;采用动态查询以后所有的这些查询都可以写在一个方法中,在这儿我结合一下hibernate谈一下动态查询。
第一种动态查询:自己封装sql
public user getUserByAllKey(String name,
String id,String tag) {
StringBuffer sb = new StringBuffer();
sb.append("from Userd where u.deleteFlag='1'");
if(name != null && !"".equals(nName)){
sb.append(" and ( name like '%"+name+"%')");
}
if((id != null) && !"0".equals(id) && !"".equals(id)){
int dir = Integer.parseInt(id);
sb.append(" and d.id in(select direc.id from FileAttribute as f where f.audit=1 and f.deleteFlag = 1 and f.sort.id ="+sortId+")");
}
String subDirIdt = null;
if(tag!= null && !"".equals(subDirId)){
subDirIdt = ","+tag+",";
sb.append(" and CONCAT(CONCAT(',',d.tag),',') like '%"+subDirIdt+"%'");
}
sb.append(" order by d.createDate desc");
return searchPaginated(sb.toString());
}
第二种:采用hibernate封装
1、创建一个Criteria实例
net.sf.hibernate.Criteria这个接口代表对一个特定的持久化类的查询。Session是用来制造Criteria实例的工厂。
Criteria crit = sess.createCriteria(Cat.class);
crit.setMaxResults(50);
List cats = crit.list();
2、缩小结果集范围
一个查询条件(Criterion)是net.sf.hibernate.expression.Criterion接口的一个实例。类net.sf.hibernate.expression.Expression定义了获得一些内置的Criterion类型。
List cats = sess.createCriteria(Cat.class)
.add( Expression.like("name", "Fritz%") )
.add( Expression.between("weight", minWeight, maxWeight) )
.list();
表达式(Expressions)可以按照逻辑分组.
List cats = sess.createCriteria(Cat.class)
.add( Expression.like("name", "Fritz%") )
.add( Expression.or(
Expression.eq( "age", new Integer(0) ),
Expression.isNull("age")
) )
.list();
List cats = sess.createCriteria(Cat.class)
.add( Expression.in( "name", new String[] { "Fritz", "Izi", "Pk" } ) )
.add( Expression.disjunction()
.add( Expression.isNull("age") )
.add( Expression.eq("age", new Integer(0) ) )
.add( Expression.eq("age", new Integer(1) ) )
.add( Expression.eq("age", new Integer(2) ) )
) )
.list();
3、对结果排序
可以使用net.sf.hibernate.expression.Order对结果集排序.
List cats = sess.createCriteria(Cat.class)
.add( Expression.like("name", "F%")
.addOrder( Order.asc("name") )
.addOrder( Order.desc("age") )
.setMaxResults(50)
.list();
再此只是简单的介绍了下hibernate的动态查询的用法,自己封装要很仔细,如果采用hibernate封装需要对hibernate有一定了解,有兴趣的朋友可以去看看hibernate中的关联,以及示例查询等