`
isiqi
  • 浏览: 16486270 次
  • 性别: Icon_minigender_1
  • 来自: 济南
社区版块
存档分类
最新评论

HibernateTemplate的使用

阅读更多

在使用前需要在Spring的配置文件applicationContext.xml中控制反转用到连接数据库中的类是注入SessionsFactory(定义一个sessionfactory的bean),并且继承继承HibernateDaoSupport类

使用HibernateTemplate的方法进行CRUD操作,其中查询操作通常可分为两种,
一种为固定条件查询,
另一种为动态多条件查询(如查询界面的实现),固定条件查询可以很方便地通过createQuery,find()等方法实现,但是我在动态条件查询的实现过程中,hibernate3.0可以实现英文的条件查询,而中文条件则会出现乱码。现将具体的过程描述如下:

1.固定条件查询

可以使用常规的方法,如

  1. getHibernateTemplate().find(),getHibernateTemplate().createQuery()等




2.动态多条件查询

由于查询条件的不确定性,我曾尝试用拼参数的方法将拼好的sql语句传入find(qlStr),但是查询时hibernate会将中文的条件报为乱码。不过如果条件全部是英文参数的话拼sql是可以的。乱码报错如下:
3:49,946 INFO [STDOUT] Hibernate:
select incometype0_.id as id, incometype0_.name as name0_, incometype0_.type_comment as type3_0_ from income_type incometype0_ where 1=1 and incometype0_.type_comment='·á????×?????'
因此这种方法无法使用。另外find()的另一种find(String arg0,Object[] arg1),采用数组参数将sql的条件参数传入的方式只是适合固定条件参数的查询,不适合这种动态多条件的中文查询,因此也无法使用。

说明:由于find(String arg0,Object[] arg1)采用数组参数的方式可以使用中文条件查询,因此可以确定不是我的编码问题。而是Hibernate3.0的find(sqlStr)方法本身的问题。

为此只能换成另一种实现途径,如下:

实现途径:
得到session ,用Query q = session.createQuery(sql);该方法返回一个Query 类型,利用q.setString(String arg0,String arg1)将参数赋值给sql的参数条件。在sql语句中拼一次参数,在setString()中也拼一次赋值。
如:

  1. publicListphraseQuery(finalStringid,finalStringname,
  2. finalStringtypecomment){
  3. StringBuffersql=newStringBuffer();
  4. sql.append("fromIncomeTypewhere1=1");
  5. if(id!=null&&id.length()>0)
  6. sql.append("andid=:id");
  7. if(name!=null&&name.length()>0)
  8. sql.append("andname=:name");
  9. if(typecomment!=null&&typecomment.length()>0)
  10. sql.append("andtypeComment=:tc");
  11. finalStringtypeSql=newString(sql);
  12. return(List)getHibernateTemplate().execute(
  13. newHibernateCallback(){
  14. publicObjectdoInHibernate(Sessionsession)
  15. throwsHibernateException,SQLException{
  16. Queryq=session.createQuery(typeSql);
  17. if(id!=null&&id.length()>0)
  18. q.setString("id",id);
  19. if(name!=null&&name.length()>0)
  20. q.setString("name",name);
  21. if(typecomment!=null
  22. &&typecomment.length()>0)
  23. q.setString("tc",typecomment);
  24. returnq.list();
  25. }
  26. });
  27. }






以上方法可以实现动态中文条件查询,在有的书中看到并不推荐用find()方法,find()只提供一些简单的HQL查询,不具有动态绑定参数的功能,在将来的hibernate新版本中,有可能会淘汰find()方法,而Query接口才是真正的HQL查询接口,提供更为丰富的功能。基于此,可能对于一个将被淘汰的方法find()不支持中文也就不足为奇了。^_^毕竟人家重心转移了。而且find()中拼sql字符串的方式虽然是实现查询的常用手段,实现起来也比较方便,但是不利于hibernate更好地利用缓存,而采用Query接口可以更好地利用缓存,提高程序执行效率。



HibernateTemplate的常用方法简介:

  1. qvoiddelete(Objectentity):删除指定持久化实例
  2. qdeleteAll(Collectionentities):删除集合内全部持久化类实例
  3. qfind(StringqueryString):根据HQL查询字符串来返回实例集合
  4. qfindByNamedQuery(StringqueryName):根据命名查询返回实例集合
  5. qget(ClassentityClass,Serializableid):根据主键加载特定持久化类的实例
  6. qsave(Objectentity):保存新的实例
  7. qsaveOrUpdate(Objectentity):根据实例状态,选择保存或者更新
  8. qupdate(Objectentity):更新实例的状态,要求entity是持久状态
  9. qsetMaxResults(intmaxResults):设置分页的大小





下面是一个完整DAO类的源代码:

  1. publicclassPersonDAOHibernateimplementsPersonDAO
  2. {
  3. //采用log4j来完成调试时的日志功能
  4. privatestaticLoglog=LogFactory.getLog(NewsDAOHibernate.class);
  5. //以私有的成员变量来保存SessionFactory。
  6. privateSessionFactorysessionFactory;
  7. //以私有变量的方式保存HibernateTemplate
  8. privateHibernateTemplatehibernateTemplate=null;
  9. //设值注入SessionFactory必需的setter方法
  10. publicvoidsetSessionFactory(SessionFactorysessionFactory)
  11. {
  12. this.sessionFactory=sessionFactory;
  13. }
  14. //初始化本DAO所需的HibernateTemplate
  15. publicHIbernateTemplategetHibernateTemplate()
  16. {
  17. //首先,检查原来的hibernateTemplate实例是否还存在
  18. if(hibernateTemplate==null)
  19. {
  20. //如果不存在,新建一个HibernateTemplate实例
  21. hibernateTemplate=newHibernateTemplate(sessionFactory);
  22. }
  23. returnhibernateTemplate;
  24. }
  25. //返回全部的人的实例
  26. publicListgetPersons()
  27. {
  28. //通过HibernateTemplate的find方法返回Person的全部实例
  29. returngetHibernateTemplate().find("fromPerson");
  30. }
  31. /**
  32. *根据主键返回特定实例
  33. *@return特定主键对应的Person实例
  34. *@param主键值
  35. publicNewsgetNews(intpersonid)
  36. {
  37. return(Person)getHibernateTemplate().get(Person.class,newInteger(personid));
  38. }
  39. /**
  40. *@person需要保存的Person实例
  41. */
  42. publicvoidsavePerson(Personperson)
  43. {
  44. getHibernateTemplate().saveOrUpdate(person);
  45. }
  46. /**
  47. *@parampersonid需要删除Person实例的主键
  48. */
  49. publicvoidremovePerson(intpersonid)
  50. {
  51. //先加载特定实例
  52. Objectp=getHibernateTemplate().load(Person.class,newInteger(personid));
  53. //删除特定实例
  54. getHibernateTemplate().delete(p);
  55. }

分享到:
评论

相关推荐

    HibernateTemplate 的常规用法.doc

    在实际应用中,DAO(Data Access Object)类通常会使用HibernateTemplate。例如,以下是一个简单的`PersonDAOImpl`类的示例: ```java public class PersonDAOImpl implements PersonDAO { private static Log log...

    关于使用HibernateTemplate

    ### 关于使用HibernateTemplate #### 一、简介与背景 在Java企业级应用开发中,持久层技术扮演着至关重要的角色。其中,Hibernate作为一款优秀的ORM(Object Relational Mapping)框架,极大地简化了数据访问层的...

    HibernateTemplate分组统计

    1. **HibernateTemplate**:是Spring框架提供的用于简化Hibernate使用的模板类。它提供了大量操作数据库的方法,包括查询、更新等,并且内置了事务管理机制。 2. **分组统计**:指通过SQL语句对查询结果按照一个或多...

    HibernateTemplate详细描述以及使用范围

    ### HibernateTemplate 的详细介绍与使用范围 #### 一、概述 在Spring框架中,`HibernateTemplate`作为ORM(Object Relational Mapping)技术中的一个重要组件,它提供了简化Hibernate操作的方法集,使得开发人员...

    HibernateTemplate的方法使用

    ### HibernateTemplate 的方法使用 #### 一、简介与配置方式 **HibernateTemplate** 是 Spring 框架中用于简化 Hibernate 使用的一个工具类。它通过 AOP(面向切面编程)的思想,封装了大量的 CRUD(创建、读取、...

    hibernateTemplate的常用方法

    通过上述介绍,我们可以看到`HibernateTemplate`的强大之处在于它不仅简化了Hibernate的集成与使用,还提供了一系列实用的方法来满足不同的业务需求。在实际项目开发中,合理利用这些方法可以大大提升开发效率和代码...

    HibernateTemplate的用法总结

    HibernateTemplate是Spring框架提供的一种操作Hibernate的方式,它简化了Hibernate的使用过程,使开发者无需关注Session的管理与事务控制,极大地提高了开发效率。本文将对HibernateTemplate的主要用法进行详细介绍...

    hibernateTemplate

    使用`HibernateTemplate`可以减少大量模板代码的编写,提高开发效率。 #### 三、HibernateTemplate核心功能详解 ##### 1. 增删改查基础操作 `HibernateTemplate`提供了多种方法来执行基本的数据库操作: - **...

    HibernateTemplate类的使用

    ### HibernateTemplate类的使用详解 #### 一、引言 在Java开发中,持久层框架Hibernate因其优秀的ORM(Object-Relational Mapping)特性被广泛应用。为了更便捷地使用Hibernate,Spring框架提供了一系列工具类来简化...

    HibernateTemplate汇总

    HibernateTemplate 是 Spring 框架中的一個关键组件,用于简化 Hibernate 的使用,提供了許多实用的方法来进行数据库操作。在本文中,我们将对 HibernateTemplate 的主要方法进行总结和解释。 ...

    HibernateTemplate的简单示例

    HibernateTemplate的简单示例

    HibernateTemplate源代码

    `HibernateTemplate`是Spring框架提供的一个强大的工具,它不仅简化了Hibernate的使用,还提供了异常转换、资源管理等功能,使得开发人员能够更加专注于业务逻辑的编写。通过对`HibernateTemplate`的学习和使用,...

    hibernateTemplate批量删除数据

    在Hibernate框架中,`HibernateTemplate`提供了一种更为简洁、易于使用的API,用于执行基本的CRUD(创建、读取、更新、删除)操作。对于批量删除数据,`HibernateTemplate`提供了`bulkUpdate()`方法,该方法通过执行...

    SSH2增删改查使用HibernateTemplate

    在这个框架中,HibernateTemplate是Spring提供的一个工具类,它简化了Hibernate的使用,使得开发者可以更方便地进行数据库操作,如增删改查。接下来,我们将深入探讨如何在SSH2中使用HibernateTemplate进行这些基本...

    hibernateTemplate常用方法.htm

    hibernateTemplate常用方法.htm

    一个模拟Spring将SessionFactory注入到HibernateTemplate的小例子

    本示例将深入探讨如何使用Spring将SessionFactory注入到HibernateTemplate中,从而实现数据库操作的便捷管理。 首先,让我们了解几个关键组件: 1. SessionFactory:这是Hibernate的核心工厂类,用于创建Session...

    Spring+Hibernate工具类所有增删改查

    与JdbcTemplate不同,HibernateTemplate使用了Hibernate ORM,可以直接操作对象,而不是SQL语句。它可以自动处理对象的持久化、加载、更新和删除等操作,使得数据库操作更符合面向对象的思维模式。此外,它还提供了...

    简单封装 HibernateTemplate 各项功能

    GenericHibernateDao 继承 HibernateDao,简单封装 HibernateTemplate 各项功能,简化基于Hibernate Dao 的编写。

    springssh 我上培训班时spring框架搭建课件

    3. **HibernateTemplate使用**:HibernateTemplate是Spring提供的用于简化Hibernate使用的类,它提供了一系列方便的方法来执行常见的CRUD操作,从而降低了代码的复杂度。 4. **DAO层设计**:最后,在业务逻辑层...

Global site tag (gtag.js) - Google Analytics