




版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、HibernateTemplate的常规用法HibernateTemplate提供非常多的常用方法来完成基本的操作,比如通常的增加、删除、修改、查询等操作,Spring 2.0更增加对命名SQL查询的支持,也增加对分页的支持。大部分情况下,使用Hibernate的常规用法,就可完成大多数DAO对象的CRUD操作。下面是HibernateTemplate的常用方法简介:q void delete(Object entity):删除指定持久化实例q deleteAll(Colle
2、ction entities):删除集合内全部持久化类实例q find(String queryString):根据HQL查询字符串来返回实例集合q findByNamedQuery(String queryName):根据命名查询返回实例集合q get(Class entityClass, Serializable id):根据主键加载特定持久化类的实例q
3、 save(Object entity):保存新的实例q saveOrUpdate(Object entity):根据实例状态,选择保存或者更新q update(Object entity):更新实例的状态,要求entity是持久状态q setMaxResults(int maxResults):设置分页的大小下面是一个完整DAO类的源代码:public class PersonDAOHibernate implem
4、ents PersonDAO /采用log4j来完成调试时的日志功能private static Log log = LogFactory.getLog(NewsDAOHibernate.class); /以私有的成员变量来保存SessionFactory。private SessionFactory sessionFactory;/以私有变量的方式保存HibernateTemplateprivate HibernateTemplate hibernateTemplate = null;
5、 /设值注入SessionFactory必需的setter方法 public void setSessionFactory(SessionFactory sessionFactory) this.sessionFactory = sessionFactory;
6、; /初始化本DAO所需的HibernateTemplate1 / 9public HIbernateTemplate getHibernateTemplate() /首先,检查原来的hibernateTemplate实例是否还存在 if ( hibernateTemplate = null) &
7、#160; /如果不存在,新建一个HibernateTemplate实例 hibernateTemplate = new HibernateTemplate(sessionFactory);&
8、#160; return hibernateTemplate; /返回全部的人的实例 public List getPersons()
9、60; /通过HibernateTemplate的find方法返回Person的全部实例 return getHibernateTemplate().find("from Person");
10、 /* * 根据主键返回特定实例 * return 特定主键对应的Person实例 * param 主键值 public News getNew
11、s(int personid) return (Person)getHibernateTemplate().get(Person.class, new Integer(personid); /*
12、160; * person 需要保存的Person实例 */ public void savePerson(Person person)
13、60; getHibernateTemplate().saveOrUpdate(person); /* * param personid 需
14、要删除Person实例的主键 * / public void removePerson(int personid) /先加载特定实例
15、; Object p = getHibernateTemplate().load(Person.class, new Integer(personid); /删除特定实例 ge
16、tHibernateTemplate().delete(p); 10.6.2 Hibernate的复杂用法HibernateCallbackHibernateTemplate还提供一种更加灵活的方式来操作数据库,通过这种方式可以完全使用Hibernate的操作方式。HibernateTemplate的灵活访问方式是通过如下两个方法完成:q Object execute(HibernateCallback action)q List exec
17、ute(HibernateCallback action)这两个方法都需要一个HibernateCallback的实例,HibernateCallback实例可在任何有效的Hibernate数据访问中使用。程序开发者通过HibernateCallback,可以完全使用Hibernate灵活的方式来访问数据库,解决Spring封装Hibernate后灵活性不足的缺陷。HibernateCallback是一个接口,该接口只有一个方法doInHibernate(org.hibernate.Session session),该方法只有一个参数Session。通常,程序中采用实现Hiberna
18、teCallback的匿名内部类来获取HibernateCallback的实例,方法doInHibernate的方法体就是Spring执行的持久化操作。具体代码如下:public class PersonDaoImpl implements PersonDao /私有实例变量保存SessionFactory private SessionFactory sessionFactory;
19、; /依赖注入必须的setter方法 public void setSessionFactory(SessionFactory sessionFactory) this.sessionFactory = sessionFactory;
20、; /* * 通过人名查找所有匹配该名的Person实例 * param name 匹配的人名 * return 匹配该任命的全部Person集合
21、0;*/ public List findPersonsByName(final String name) /创建HibernateTemplate实例
22、 HibernateTemplate hibernateTemplate = new HibernateTemplate(this.sessionFactory); /返回HibernateTempl
23、ate的execute的结果 return (List) hibernateTemplate.execute( /创建匿名内部类 &
24、#160; new HibernateCallback() public Object doInHiber
25、nate(Session session) throws HibernateException
26、 /使用条件查询的方法返回 List result = session.createCriteria(Person.class)
27、160;
28、160; .add(Restrictions.like(“name”, name+”%”)
29、160; .list();
30、; return result; &
31、#160; ); 注意:方法doInHibernate方法内可以访问Session,该Session对象是绑定到该线程的Session实例。该方法内的持久层操作,与不使用Spring时的持久层操作完全相同。这保证对于复杂的持久层访问,依然可以使用Hibernate的访问方式。使用 HibernateTemplate 实现分页查询 最近有同学
32、做项目的时候发现 Spring 整合 Hibernate 时候用的 HibernateTemplate 不支持分页, 上网搜了搜找到结果并测试成功, 只需要用下面的方法就能分页:/* 使用hql 语句进行操作* param hql HSQL 查询语句* param offset 开始取数据的下标* param length 读取数据记录数* return List 结果集*/public List getListForPage(final String hql, final int offset, final int length) List list = getHibernateT
33、emplate().executeFind(new HibernateCallback() public Object doInHibernate(Session session) throws HibernateException, SQLException Query query = session.createQuery(hql); query.setFirstResult(offset); query.setMaxResults(length); List list = query.list(); return list; );return list;使用HibernateTempla
34、te的方法进行CRUD操作,其中查询操作通常可分为两种,一种为固定条件查询,另一种为动态多条件查询(如查询界面的实现),固定条件查询可以很方便地通过createQuery,find()等方法实现,但是我在动态条件查询的实现过程中,hibernate3.0可以实现英文的条件查询,而中文条件则会出现乱码。现将具体的过程描述如下: 1.固定条件查询 可以使用常规的方法,如getHibernateTemplate().find(),getHibernateTemplate().createQuery()等
35、 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
36、 1=1 and incometype0_.type_comment='·á?×?'因此这种方法无法使用。另外find()的另一种find(String arg0,Object arg1),采用数组参数将的条件参数传入的方式只是适合固定条件参数的查询,不适合这种动态多条件的中文查询,因此也无法使用。说明:由于find(String arg0,Object arg1)采用数组参数的方式可以使用中文条件查询,因此可以确定不是我的编码问题。而是Hibernate3.0的find(sqlStr)方法本身的问题。为此只能换成另一种实现途径,如下:实现途径:得
37、到session ,用Query q = session.createQuery(sql);该方法返回一个Query 类型,利用q.setString(String arg0,String arg1)将参数赋值给sql的参数条件。在sql语句中拼一次参数,在setString()中也拼一次赋值。如:StringBuffer sql = new StringBuffer(); sql.append("from IncomeType where 1=1 "); if(id!=null&&id.
38、length()>0) sql.append(" and id = :id "); if(name!=null&&name.length()>0) sql.append(" and name = :name "); if(typecomment!=null&&typecomment.length()>0) sql.append(" and typ
39、eComment = :tc "); final String typeSql = new String(sql);intyList = (List)getHibernateTemplate().execute( new HibernateCallback() .
40、60; public Object doInHibernate(Session session) throws HibernateException, SQLException .
41、160; Query q = session.createQuery(typeSql); if(id!=null&&id.length()>0)
42、160; q.setString("id",id); if(name!=null&&name.length()>0)
43、 q.setString("name",name); if(typecomment!=null&&typecomment.
44、length()>0) q.setString("tc",typecomment); return q.list();
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 河北正定师范高等专科学校《公司治理与财务战略》2023-2024学年第二学期期末试卷
- 南京师范大学中北学院《地理专业导论与创业基础》2023-2024学年第二学期期末试卷
- 三亚理工职业学院《结晶学与矿物学实验》2023-2024学年第二学期期末试卷
- 燕山大学《人因交互与可用性测试》2023-2024学年第二学期期末试卷
- 海南比勒费尔德应用科学大学《3D效果图制作》2023-2024学年第二学期期末试卷
- 海南经贸职业技术学院《动物学》2023-2024学年第二学期期末试卷
- 沈阳农业大学《嵌入式软件开发技术》2023-2024学年第二学期期末试卷
- 湖南三一工业职业技术学院《金属切削原理及刀具》2023-2024学年第二学期期末试卷
- 甘肃民族师范学院《现代汉语Ⅱ》2023-2024学年第二学期期末试卷
- 江苏警官学院《通信系统DSP》2023-2024学年第二学期期末试卷
- 颈部肿块诊断及鉴别诊断课件
- 物理人教版(2019)必修第三册闭合电路的欧姆定律
- 汽车前保险杠结构及安全能分析学士学位参考
- 配电室八项制度(八张)
- 清算方案模板9篇
- 个体诊所药品管理制度-范文
- 中国民间艺术的奇妙之旅知到章节答案智慧树2023年南昌大学
- 数学北师大版五年级下册相遇问题PPT
- 杨浦区2019学年第二学期期末考试八年级英语试卷(含答案)
- 电力企业安全风险分级管控和隐患排查治理双重预防体系规范
- 事故事件调查处理程序
评论
0/150
提交评论