spring接着又把业务类中的查询也封装成了find()
//用来实现分页
/*HibernateTemplate ht=this.getHibernateTemplate();
DetachedCriteria criteria=DetachedCriteria.forClass(Paper.class);
ht.findByCriteria(criteria, firstResult, maxResults);*/
this.getHibernateTemplate().findByCriteria(criteria, firstResult, maxResults)
//比较局限。User中几个有值就查询几个(主键和外键是无法的)条件的拼接只能是等于like
//常用登录查询
this.getHibernateTemplate().findByExample(User);
//删除一个数组
this.getHibernateTemplate().deleteAll(new ArrayList());
//命名查询
this.getHibernateTemplate().findByNamedQuery("name of the hql");
//第一个数组是变量名的数组,第二个是变量值的数组(冒号的命名查询)
this.getHibernateTemplate().findByNamedParam("from :name", new Object[], new String[]);
//立即清理缓存,立刻执行
this.getHibernateTemplate().flush();
//按照主键查询
this.getHibernateTemplate().get(entityClass, id);//load
//增删改
this.getHibernateTemplate().bulkUpdate("hql ?",1,"abc",new Date());
模板和回调
1、模板虽好,但有得有失
a、有时候我们需要更加灵活
2、spring提供了回调机制
a、模板固话了不变得、流程化的内容,简化使用
b、回调允许我们在固化的流程中加入变化的内容
public List<ClaimVoucher> find(final int first, final int pageSize) {
//模板和回调-->回调就是为了解决模板中不能实现的
return this.getHibernateTemplate().executeFind(new HibernateCallback() { @Override
public List doInHibernate(Session arg0)
throws HibernateException, SQLException {
// TODO Auto-generated method stub
return arg0.createQuery(" from ClaimVoucher c")
.setFirstResult((first-1)*pageSize)
.setMaxResults(pageSize)
.list();
}
});