您的位置:首页 > 数据库

Hibernate的getHibernateTemplate()对数据库进行增删改的方法使用

2017-07-08 18:11 405 查看
代码如下:

@Override
public TFwpj getTFwpjByPjdxidZjhmPjzt(String pjdxId, String zjhm, int pjzt) {
String hql = " from TFwpj where CPjdxId = ? and CZjhm = ? and NPjzt=? ";
List<TFwpj> list = this.getHibernateTemplate().find(hql, pjdxId, zjhm, pjzt);
if (list.size() != 0) {
return list.get(0);
} else {
return null;
}
}


注意:类中如果需要使用getHibernateTemplate,则该类必须继承HibernateDaoSupport,继承之后就可以直接使用了,不用配置

总结:

HibernateTemplate提供非常多的常用方法来完成基本的操作,比如通常的增加、删除、修改、查询等操作,Spring 2.0更增加对命名SQL查询的支持,也增加对分页的支持。大部分情况下,使用Hibernate的常规用法,就可完成大多数DAO对象的CRUD操作。下面是HibernateTemplate的常用方法简介:
q      void delete(Object entity):删除指定持久化实例
q      deleteAll(Collection entities):删除集合内全部持久化类实例
q      find(String queryString):根据HQL查询字符串来返回实例集合
q      findByNamedQuery(String queryName):根据命名查询返回实例集合
q      get(Class entityClass, Serializable id):根据主键加载特定持久化类的实例
q      save(Object entity):保存新的实例
q      saveOrUpdate(Object entity):根据实例状态,选择保存或者更新
q      update(Object entity):更新实例的状态,要求entity是持久状态
q      setMaxResults(int maxResults):设置分页的大小
getHibernateTemplate已经封装好了一些基本的方法,可以直接去用,也就是template嘛,
而getSession只是获取一个数据工厂的session,然后大部分方法都需要自己写,加hql语句,然后用query方法执行

谈不上什么优点缺点,类似添加删除更新这样的可以直接用getHibernateTemplate而大部分带条件查询的就需要用getSession自己写了
项目中遇到的使用getHibernateTemplate().find方法的代码:
public List<TZxDsr> getZxDsrList(String bh) {
String hql = "from TZxDsr dsr where dsr.id.CBh=?";
return this.getHibernateTemplate().find(hql, bh);
}





                                            
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: