Spring和Hibernate集成的HibernateTemplate的一些常用方法总结
1:get/load存取单条数据
- public Teacher getTeacherById(Long id) {
- return (Teacher)this.hibernateTemplate.get(Teacher.class, id);
- }
- public Teacher getTeacherById(Long id) {
- return (Teacher)this.hibernateTemplate.load(Teacher.class, id);
- }
2:find/iterate查询操作
- public Iterator getTeachersByAge(int age) {
- Iterator iterator = null;
- //使用find方法
- List list = (List)this.hibernateTemplate().find("from Teacher t where t.age>?", new Integer(age));
- iterator = list.iterator();
- //使用iterator方法
- iterator = this.hibernateTemplate().iterate("from Teacher t where t.age>?", new Integer(age));
- return iterator;
- }
find和iterato的区别主要是iterate采用了N+1次查询,对于大批量查询,比如查询10000条记录,那么iterate就要执行10000+1次查询,find和iterate应根据具体的实际
情况来使用,对于频繁的写操作对象,应使用find查询,而对于一些只读的数据对象,应使用iterate操作,因为iterate操作使用了Hibernate的缓存机制
3:save/update/saveOrUpdate/delete 保存/更新/删除操作
- public void save(Teacher teacher) {
- this.hibernateTemplate.save(teacher);
- }
- public void update(Teacher teacher) {
- this.hibernateTemplate.update(teacher);
- }
- public void update(Teacher teacher) {
- this.hibernateTemplate.saveOrUpdate(teacher);
- }
- public void update(Teacher teacher) {
- this.hibernateTemplate.delete(teacher);
- }
4:bulkUpdate批量删除或者更新
bulkUpdate提供了批量删除和更新,直接转换为相应的update/delete SQL进行批量删除和更新
- public void batchDelete(String name, int age) {
- this.hibernateTemplate.bulkUpdate("delete Teacher where name=? and age = ?", new Object[]{name, age});
- }
- public void batchDelete(String name, String newName) {
- this.hibernateTemplate.bulkUpdate("update Teacher set name=? where name=?", new Object[]{newName, name});
- }
此时要注意的一个问题是,使用bulkUpdate操作,必须手工清除相关对象在Hibernate中的缓存(包括一级缓存和二级缓存)
5:execute核心方法
- public Object execute(HibernateCallBack action, boolean exposeNativeSession) throws DataAccessException {
- //获取一个Session
- Session session = getSession();
- //当前session是否在事务中
- boolean existingTransaction = SessionFactoryUtils.isSessionTransactional(session, getSessionFactory());
- FlushMode previousFlushMode = null;
- try {
- previousFlushMode = applyFlushMode(session, existingTransaction); //应用flush模式
- enableFilters(session);
- //暴露给action的session
- Session sessionToExpose = (exposeNativeSession? session: createSessionProxy(session));
- //执行action
- Object result = action.doInHibernate(sessionToExpose);
- flushIfNecessary(session, existingTransaction);
- return result;
- } catch(HibernateException ex) {
- throw convertHibernateAccessException(ex);
- } catch(SQLException ex) {
- throw convertJdbcAccessException(ex);
- } catch(RuntimeException ex) {
- throw ex;
- } finally {
- //如果session在事务中,则不关闭session
- if(existingTransaction) {
- disableFilters(session);
- if(previousFlushMode != null) {
- session.setFlushMode(previousFlushMode);
- }
- } else {
- //释放session
- SessionFactoryUtils.releaseSession(session, getSessionFactory());
- }
- }
- }
*HibernateCallBack,一般用来实现特定的业务逻辑
*exposeNativeSession:是一个布尔值,要暴露给HibernateCallBack实际的session对象,而不是一个代理过的对象
6:一般情况下,只有HIberateTemplate提供的方法不能满足要求时才使用execute方法,它的使用情况如下所示,
- public void createDatabaseSchema() throws DataAccessException {
- HibernateTemplate hibernateTemplate = new HibernateTemplate(this.sessionFactory);
- //调用HibernateTempalte的execute方法
- hibernateTemplate.execute(new HibernateCallback() {
- public Object doInHibernate(Session session) throws HibernateException, SQLException { //
实现HibernateCallback的doInHibernate方法 - //具体实现
- Connection conn = session.connection();
- final Dialect dialect = Dialect.getDialect(configuration.getProperties);
- String[] sql = configuration.generateSchemaCreationScript(dialect);
- executeSchemaScript(conn, sql);
- }
- });
- }
使用execute方法的重点是实现
HibernateCallback的doInHibernate方法,它会传递一个Session实例,可以使用此Session实例操作数据库,由此
看出execute方法的好处是应用程序不用关心session的创建和释放,只需要处理关心的业务逻辑即可。
Spring和Hibernate集成的HibernateTemplate的一些常用方法总结的更多相关文章
- Spring与Hibernate集成中的Session问题
主要讨论Spring与Hibernate集成中的session问题 1.通过getSession()方法获得session进行操作 public class Test extends Hibernat ...
- spring和hibernate集成事物管理配置方法
spring+hibernate,采用声明式事务 1.声明式事务配置 * 配置SessionFactory * 配置事务管理器 * 事务的传播特性 * 那些类那些方法使用事务 2.编写业务逻辑方法 * ...
- Spring和Hibernate集成配置
<?xml version="1.0" encoding="UTF-8"?><beans xmlns="http://www.spr ...
- Spring 与 Hibernate 集成 Transactional设置为只读
@Transactional标签用于标记ServiceImpl使用事务,并且能够打开一个sessionFactory的session,并且打开事务. 如果在这个标签为@Transactional(pr ...
- Hibernate(十)--spring整合hibernate
结构: Spring和Hibernate整合借助于HibernateTemplate applicationContext.xml <?xml version="1.0" e ...
- 【译】Spring 4 + Hibernate 4 + Mysql + Maven集成例子(注解 + XML)
前言 译文链接:http://websystique.com/spring/spring4-hibernate4-mysql-maven-integration-example-using-annot ...
- Java Hour 56 Spring 和 Hibernate 的集成
上一章节我们完成了一个简单的Spring 的试验品,这章要让Spring 上战场了,不要慌,步骤都是一样的. Spring 对 Hibernate 的支持是很多方面的,第一个战场是SessionFac ...
- Spring第12篇—— Spring对Hibernate的SessionFactory的集成功能
由于Spring和Hibernate处于不同的层次,Spring关心的是业务逻辑之间的组合关系,Spring提供了对他们的强大的管理能力, 而Hibernate完成了OR的映射,使开发人员不用再去关心 ...
- 菜鸟学习Spring——60s学会Spring与Hibernate的集成
一.概述. Spring与Hibernate的集成在企业应用中是很常用的做法通过Spring和Hibernate的结合能提高我们代码的灵活性和开发效率,下面我就一步一步的给大家讲述Spring如何和H ...
随机推荐
- 8 种 NoSQL 数据库系统对比
导读:Kristóf Kovács 是一位软件架构师和咨询顾问,他最近发布了一片对比各种类型NoSQL数据库的文章. 虽然SQL数据库是非常有用的工具,但经历了15年的一支独秀之后垄断即将被打破.这只 ...
- shell 删除日志
一般线上服务的日志都是采用回滚的防止,写一定数量的日志 或是有管理工具定期去转移老旧日志 前几天删除一个测试环境的日志,只保留两天的日志,结果把正在写的日志都给删掉了,不得不重启了服务,经过这一次的错 ...
- MySQL 5.6 复制:GTID 的优点和限制(第一部分)
全局事务标示符(Global Transactions Identifier)是MySQL 5.6复制的一个新特性.它为维护特定的复制拓扑结构下服务器的DBA们大幅度改善他们的工作状况提供了多种可能性 ...
- 定义页面的Dispose方法:[before]unload事件启示录
前言 最近实施的同事报障,说用户审批流程后直接关闭浏览器,操作十余次后系统就报用户会话数超过上限,咨询4A同事后得知登陆后需要显式调用登出API才能清理4A端,否则必然会超出会话上限. 即使在页面上增 ...
- Android中GridView滚动到底部加载数据终极版
之前在项目中有一个需求是需要GridView控件,滚动到底部自动加载.但是呢GridView控件并不提供诸如ListView监听滚动到底部的onScrollListener方法,为了实现这样一个效果, ...
- <转>准备Eclips+python+robot framework环境
关于python: path添加:C:\Python27;C:\Python27\Scripts; 新加一项: PYTHON_HOME C:\Python27 再不行的话,加一个用户变量: P ...
- Linux Systemd——在RHEL/CentOS 7中启动/停止/重启服务
RHEL/CentOS 7.0中一个最主要的改变,就是切换到了systemd.它用于替代红帽企业版Linux前任版本中的SysV和Upstart,对系统和服务进行管理.systemd兼容SysV和Li ...
- 【转载】epoll的使用
select,poll,epoll简介 select select本质上是通过设置或者检查存放fd标志位的数据结构来进行下一步处理.这样所带来的缺点是: 1 单个进程可监视的fd数量被限制 2 需要维 ...
- sensor BMA250源代码执行分析
重力传感器是根据压电效应的原理来工作的. 所谓的压电效应就是 “对于不存在对称中心的异极晶体加在晶体上的外力除了使晶体发生形变以外,还将改变晶体的极化状态,在晶体内部建立电场,这种由于机械力作用使 ...
- Android Studio的安装使用记录[持续更新]
参考资料: Windows环境下Android Studio v1.0安装教程 http://ask.android-studio.org/?/article/9 1. 下载与安装 在http://w ...