Chinaunix首页 | 论坛 | 博客
  • 博客访问: 75691
  • 博文数量: 8
  • 博客积分: 255
  • 博客等级: 二等列兵
  • 技术积分: 135
  • 用 户 组: 普通用户
  • 注册时间: 2012-03-21 20:46
文章分类
文章存档

2012年(8)

我的朋友

分类: 系统运维

2012-04-18 17:56:00

 

getHibernateTemplate()

spring 中获得由spring所配置的hibernate的操作对象,然后利用此对象进行,保存,修改和删除等操作,此方法是在配置了spring以后,hibernate由spring接管,不直接使用hibernate的session了 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自己写了

&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&

主流技术到底就是主流技术,效率就不一般。
Hibernate封装了对数据库的例行操作,比单纯的jdbc的DAO,开发效率要高很多了。而Springframework对Hibernate的操作又进行了进一步的包装,又将开发效率提升不少。下面的例子是Spring自己给的petclinic的样本程序。
原来b/s架构的大量数据库操作可以这么轻松搞定

 

原文地址:http://blog.csdn.net/wallwind/article/details/6269094

阅读(788) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~