1:get/load存取单条数据

  1. public Teacher getTeacherById(Long id) {
  2. return (Teacher)this.hibernateTemplate.get(Teacher.class, id);
  3. }
  4. public Teacher getTeacherById(Long id) {
  5. return (Teacher)this.hibernateTemplate.load(Teacher.class, id);
  6. }

2:find/iterate查询操作

  1. public Iterator getTeachersByAge(int age) {
  2. Iterator iterator = null;
  3. //使用find方法
  4. List list = (List)this.hibernateTemplate().find("from Teacher t where t.age>?", new Integer(age));
  5. iterator = list.iterator();
  6. //使用iterator方法
  7. iterator = this.hibernateTemplate().iterate("from Teacher t where t.age>?", new Integer(age));
  8. return iterator;
  9. }

find和iterato的区别主要是iterate采用了N+1次查询,对于大批量查询,比如查询10000条记录,那么iterate就要执行10000+1次查询,find和iterate应根据具体的实际

情况来使用,对于频繁的写操作对象,应使用find查询,而对于一些只读的数据对象,应使用iterate操作,因为iterate操作使用了Hibernate的缓存机制

3:save/update/saveOrUpdate/delete 保存/更新/删除操作

  1. public void save(Teacher teacher) {
  2. this.hibernateTemplate.save(teacher);
  3. }
  1. public void update(Teacher teacher) {
  2. this.hibernateTemplate.update(teacher);
  3. }
  1. public void update(Teacher teacher) {
  2. this.hibernateTemplate.saveOrUpdate(teacher);
  3. }
  1. public void update(Teacher teacher) {
  2. this.hibernateTemplate.delete(teacher);
  3. }

4:bulkUpdate批量删除或者更新

bulkUpdate提供了批量删除和更新,直接转换为相应的update/delete SQL进行批量删除和更新

  1. public void batchDelete(String name, int age) {
  2. this.hibernateTemplate.bulkUpdate("delete Teacher where name=? and age = ?", new Object[]{name, age});
  3. }
  1. public void batchDelete(String name, String newName) {
  2. this.hibernateTemplate.bulkUpdate("update Teacher set name=? where name=?", new Object[]{newName, name});
  3. }

此时要注意的一个问题是,使用bulkUpdate操作,必须手工清除相关对象在Hibernate中的缓存(包括一级缓存和二级缓存)

5:execute核心方法

  1. public Object execute(HibernateCallBack action, boolean exposeNativeSession) throws DataAccessException {
  2. //获取一个Session
  3. Session session = getSession();
  4. //当前session是否在事务中
  5. boolean existingTransaction = SessionFactoryUtils.isSessionTransactional(session, getSessionFactory());
  6. FlushMode previousFlushMode = null;
  7. try {
  8. previousFlushMode = applyFlushMode(session, existingTransaction); //应用flush模式
  9. enableFilters(session);
  10. //暴露给action的session
  11. Session sessionToExpose = (exposeNativeSession? session: createSessionProxy(session));
  12. //执行action
  13. Object result = action.doInHibernate(sessionToExpose);
  14. flushIfNecessary(session, existingTransaction);
  15. return result;
  16. } catch(HibernateException ex) {
  17. throw convertHibernateAccessException(ex);
  18. } catch(SQLException ex) {
  19. throw convertJdbcAccessException(ex);
  20. } catch(RuntimeException ex) {
  21. throw ex;
  22. } finally {
  23. //如果session在事务中,则不关闭session
  24. if(existingTransaction) {
  25. disableFilters(session);
  26. if(previousFlushMode != null) {
  27. session.setFlushMode(previousFlushMode);
  28. }
  29. } else {
  30. //释放session
  31. SessionFactoryUtils.releaseSession(session, getSessionFactory());
  32. }
  33. }
  34. }

*HibernateCallBack,一般用来实现特定的业务逻辑

*exposeNativeSession:是一个布尔值,要暴露给HibernateCallBack实际的session对象,而不是一个代理过的对象

6:一般情况下,只有HIberateTemplate提供的方法不能满足要求时才使用execute方法,它的使用情况如下所示,

  1. public void createDatabaseSchema() throws DataAccessException {
  2. HibernateTemplate hibernateTemplate = new HibernateTemplate(this.sessionFactory);
  3. //调用HibernateTempalte的execute方法
  4. hibernateTemplate.execute(new HibernateCallback() {
  5. public Object doInHibernate(Session session) throws HibernateException, SQLException {  //
    实现HibernateCallback的doInHibernate方法
  6. //具体实现
  7. Connection conn = session.connection();
  8. final Dialect dialect = Dialect.getDialect(configuration.getProperties);
  9. String[] sql = configuration.generateSchemaCreationScript(dialect);
  10. executeSchemaScript(conn, sql);
  11. }
  12. });
  13. }

使用execute方法的重点是实现
HibernateCallback的doInHibernate方法,它会传递一个Session实例,可以使用此Session实例操作数据库,由此
看出execute方法的好处是应用程序不用关心session的创建和释放,只需要处理关心的业务逻辑即可。

Spring和Hibernate集成的HibernateTemplate的一些常用方法总结的更多相关文章

  1. Spring与Hibernate集成中的Session问题

    主要讨论Spring与Hibernate集成中的session问题 1.通过getSession()方法获得session进行操作 public class Test extends Hibernat ...

  2. spring和hibernate集成事物管理配置方法

    spring+hibernate,采用声明式事务 1.声明式事务配置 * 配置SessionFactory * 配置事务管理器 * 事务的传播特性 * 那些类那些方法使用事务 2.编写业务逻辑方法 * ...

  3. Spring和Hibernate集成配置

    <?xml version="1.0" encoding="UTF-8"?><beans xmlns="http://www.spr ...

  4. Spring 与 Hibernate 集成 Transactional设置为只读

    @Transactional标签用于标记ServiceImpl使用事务,并且能够打开一个sessionFactory的session,并且打开事务. 如果在这个标签为@Transactional(pr ...

  5. Hibernate(十)--spring整合hibernate

    结构: Spring和Hibernate整合借助于HibernateTemplate applicationContext.xml <?xml version="1.0" e ...

  6. 【译】Spring 4 + Hibernate 4 + Mysql + Maven集成例子(注解 + XML)

    前言 译文链接:http://websystique.com/spring/spring4-hibernate4-mysql-maven-integration-example-using-annot ...

  7. Java Hour 56 Spring 和 Hibernate 的集成

    上一章节我们完成了一个简单的Spring 的试验品,这章要让Spring 上战场了,不要慌,步骤都是一样的. Spring 对 Hibernate 的支持是很多方面的,第一个战场是SessionFac ...

  8. Spring第12篇—— Spring对Hibernate的SessionFactory的集成功能

    由于Spring和Hibernate处于不同的层次,Spring关心的是业务逻辑之间的组合关系,Spring提供了对他们的强大的管理能力, 而Hibernate完成了OR的映射,使开发人员不用再去关心 ...

  9. 菜鸟学习Spring——60s学会Spring与Hibernate的集成

    一.概述. Spring与Hibernate的集成在企业应用中是很常用的做法通过Spring和Hibernate的结合能提高我们代码的灵活性和开发效率,下面我就一步一步的给大家讲述Spring如何和H ...

随机推荐

  1. c& c++ enum

    1.为什么要用enum       写程序时,我们常常需要为某个对象关联一组可选alternative属性.例如,学生的成绩分A,B,C,D等,天气分sunny, cloudy, rainy等等.   ...

  2. Android设计模式之命令模式、策略模式、模板方法模式

    命令模式是其它很多行为型模式的基础模式.策略模式是命令模式的一个特例,而策略模式又和模板方法模式都是算法替换的实现,只不过替换的方式不同.下面来谈谈这三个模式. 命令模式 将一个请求封装为一个对象,从 ...

  3. 深入浅出 iOS 之生命周期

    转:http://blog.csdn.net/kesalin/article/details/6691766 iOS应用程序的生命周期相比 Android 应用程序的生命周期来说,没那么简明易懂,但是 ...

  4. java 读取TXT文件的方法

    java读取txt文件内容.可以作如下理解: 首先获得一个文件句柄.File file = new File(); file即为文件句柄.两人之间连通电话网络了.接下来可以开始打电话了. 通过这条线路 ...

  5. Delphi 712操作word

    //导出Wordprocedure TFrm_Computing.ExportWord;var wordApp, WordDoc, WrdSelection, wrdtable, wrdtable1, ...

  6. JDBC获取表的主键

    JDBC获取表的主键 案例,创建订单,并根据订单号向订单明细表插入数据 sql语句: 创建两表 create table orders(  id number(4) primary key,  cus ...

  7. 【整理】Visual Studio快捷键

    说明 很多开发人员使用Visual Studio的时候,由于对VS快捷键不熟悉,会影响到实际的开发效率.其实,有很多我们不知道(或已知)的快捷键,在我们熟练运用以后,能够提高我们整体的工作效率.以下是 ...

  8. 《GettingThingsDone》--GTD学习笔记(二)-GTD实践指导

    一.准备阶段的建议: 高级的工作管理方法就是学会一套系统并付诸实施,直到将这套系统和方法融入你的工作和生活中. 通过行动使自己感觉良好,要比通过使自己感觉良好而进入一种较佳的行动状态容易的多. 当你在 ...

  9. 《Genesis-3D开源游戏引擎完整实例教程-2D射击游戏篇:简介及目录》(附上完整工程文件)

    G-3D引擎2D射击类游戏制作教程 游戏类型: 打飞机游戏属于射击类游戏中的一种,可以划分为卷轴射击类游戏. 视觉表现类型为:2D 框架简介: Genesis-3D引擎不仅为开发者提供一个3D游戏制作 ...

  10. MEAN stack 做网站【1】

    做一个小project,学习如何用MEAN技术栈来搭建网站. JavaScript新手,不足之处,请指出.(系统为win10) 搭建环境: 安装Node.JS (略过) 安装MySQL,MongoDB ...