初学,想了解一下Struts+Hibernate+Spring Tomcat+JSP我看了个列子,查询语句好像是自动生成的,我到现在还没弄明白怎么实现条件查询和排序,那位高手帮忙说一下 解决方案 » 免费领取超大流量手机卡,每月29元包185G流量+100分钟通话, 中国电信官方发货 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(); 有很多预制的条件类型(Expression的子类)。有一个特别有用,可以让你直接嵌入SQL。 List cats = sess.createCriteria(Cat.class) .add( Expression.sql("lower($alias.name) like lower(?)", "Fritz%", Hibernate.STRING) ) .list(); 其中的{alias}是一个占位符,它将会被所查询实体的行别名所替代。(原文:The {alias} placeholder with be replaced by the row alias of the queried entity.) 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(); 找了点资料你参考下,第一句应该是:Criteria crit = session.createCriteria(Cat.class); 能帮我解析一下一个查询的函数吗? public Collection dataQuery5Query(ItemData itemData,Ipinfor ipinfor1,boolean isAdmBankId) { ArrayList al=new ArrayList(); al.add(itemData.getId().getSysDate()); al.add(itemData.getId().getSysRound()); al.add("%" + itemData.getField4() + "%"); if(ipinfor1.getIpinforValue().equals(itemData.getId().getSysDate())){ return itemDataDao.getBeansByParams("findTotalItemData", al); }else{ return itemDataDao.getBeansByParams("findTotalItemDataHist", al); } }那上面这个它好像是把al的3个参数传给itemDataDao.getBeansByParams实现查询的它在Tomcat显示出来的条件是where SysDate=? and SysRound=? and Field4 like ?但是我看到 public Collection getBeanByBean(ItemData bean, MatchMode mode) throws DaoException{ return super.getBeansByBean(bean, mode);itemDataDao应该是个数据集,这个根本看不出来它的条件是怎么实现的 汗! 还在问这个问题呢- -! itemDataDao就是个数据访问对象,你要知道具体怎么查询的,你需要看看itemDataDao中的getBeansByParams是如何实现的。如果用了spring我想itemDataDao应该是被注入的。你就要根据spring的配置文件,找到实现itemDataDao的类,然后到这个类中找getBeansByParams具体的实现! 去itemDataDao的实现类里看看吧 ssh你所指的那个自动生成的查询语句是hibernate里面的hql语句 增删改查包括带条件查询和分页都有..实现一个hibernateSu..什么接口。。记不清了.. 可以到网上去搜搜hql语句和sql语句的区别我以前用的ssh都是用hql语句..最明显的是hql只写from table前面都没有.其次就是多表连接有写不一样.. Java 测试题 求解答 谢谢!! oracle的安装和使用好难啊 struts1.2 使用FormFile上传附件超过2M就报错 ejb远程调用home类型无法转换,请教高手,急!! 数据文件的导入 数据库连接的时候问题 菜鸟问题 求助如何配置JSP环境 在线等 做J2EE开发的朋友请进 关于基本的数据类型的范围问题? 使用poi生成表格,读出后报错 如何解决404错误 iReport包
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();
有很多预制的条件类型(Expression的子类)。有一个特别有用,可以让你直接嵌入SQL。
List cats = sess.createCriteria(Cat.class)
.add( Expression.sql("lower($alias.name) like lower(?)", "Fritz%", Hibernate.STRING) )
.list();
其中的{alias}是一个占位符,它将会被所查询实体的行别名所替代。(原文:The {alias} placeholder with be replaced by the row alias of the queried entity.)
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();
public Collection dataQuery5Query(ItemData itemData,Ipinfor ipinfor1,boolean isAdmBankId) { ArrayList al=new ArrayList();
al.add(itemData.getId().getSysDate());
al.add(itemData.getId().getSysRound());
al.add("%" + itemData.getField4() + "%");
if(ipinfor1.getIpinforValue().equals(itemData.getId().getSysDate())){
return itemDataDao.getBeansByParams("findTotalItemData", al);
}else{
return itemDataDao.getBeansByParams("findTotalItemDataHist", al);
}
}
那上面这个它好像是把al的3个参数传给itemDataDao.getBeansByParams实现查询的
它在Tomcat显示出来的条件是where SysDate=? and SysRound=? and Field4 like ?
但是我看到
public Collection getBeanByBean(ItemData bean, MatchMode mode) throws DaoException{
return super.getBeansByBean(bean, mode);
itemDataDao应该是个数据集,这个根本看不出来它的条件是怎么实现的
itemDataDao就是个数据访问对象,你要知道具体怎么查询的,你需要看看itemDataDao中的getBeansByParams是如何实现的。如果用了spring我想itemDataDao应该是被注入的。你就要根据spring的配置文件,找到实现itemDataDao的类,然后到这个类中找getBeansByParams具体的实现!
增删改查包括带条件查询和分页都有..实现一个hibernateSu..什么接口。。记不清了..
可以到网上去搜搜hql语句和sql语句的区别
我以前用的ssh都是用hql语句..最明显的是hql只写from table
前面都没有.其次就是多表连接有写不一样..