Spring管理session的一些认识和用法心得

简介: 在项目开发中,使用了SSH框架集成时,多处都会用到Session。在对Session的使用维护上,有如下几种看法: 1.getCurrentSession(); 获得当前会话中的session,该session有容器自行维护管理,Spring可以代理事务。 2.this.getSession(); 从当前的执行中获得或创建一个hibernate的session对象,需要自己手动关
在项目开发中,使用了SSH框架集成时,多处都会用到Session。在对Session的使用维护上,有如下几种看法:
1.getCurrentSession();
获得当前会话中的session,该session有容器自行维护管理,Spring可以代理事务。
2.this.getSession();
从当前的执行中获得或创建一个hibernate的session对象,需要自己手动关闭,以释放连接资源。
3.openSession();
调用函数自行创建一个数据库的连接,并将其打开,在使用Spring操作非查询语句的请况下,Spring的事务对该session对象不起到事务管理的作用,所以该session对象应当由程序员自己关闭,释放连接资源。

以上三种操作session的方式,我们都离不开这样的操作主线:

打开Session,开始一个事务,处理异常,提交一个事务,最后关闭一个Session。

如果我们自己只专注于业务,不想去作这些重复而繁琐的操作,那这样的一套操作对我们来讲太繁琐了!

相信任何一个程序员,都不想重复敲着那一遍又一遍雷同的代码!


在Spring的框架中,HibernateTemplate包装了Hibernate的代码,提供了相当多有用的辅助功能。Spring的HibernateTemplate可以帮我们完成这样的工作,使用声明式的配置来实现这样的功能。既然使用了SSH集成,那就要充分利用好Spring的这个功能吧,当然如果你还担心spring到底有没有关闭session的话,不妨看看这个文章:【那个看起来有点2但不2的程序员做的一件事:验证HibernateTemplate有没有关闭session:http://songzj.iteye.com/blog/766148】


但是如果我们非得使用session来完成业务而又不想去管事务上的事,那就意味着我们放弃了上面所说的一切好处!

Spring,她依然可以帮我们完成这种有点BT的需求。


HibernateTemplate提供HibernateCallback,就是为了满足这种使用了HibernateTemplate的情况下,仍然需要直接访问Session的需求而来的。它提供了在HibernateTemplate里面直接访问Session的能力,程序员不必人为的管理session对象(这个就是使用HibernateCallback的原因http://blog.163.com/yeyhan/blog/static/44179333201022942856795/)。

首先,应该确保我们的DAO已经继承了HibernateDaoSupport。

于是,如果我们可以参考如下形式书写:

  1. @SuppressWarnings("unchecked"
  2.     public Page queryData(final String countSql, final String resultSql, 
  3.             final int startIndex, final int pageSize, final long total) { 
  4.         Page result = (Page) getHibernateTemplate().execute( 
  5.                 new HibernateCallback() { 
  6.                     public Object doInHibernate(Session session) 
  7.                             throws HibernateException, SQLException { 
  8.                         long totalCount = 0
  9.                         if (total < 0) { 
  10.                             List countlist = session.createSQLQuery(countSql) 
  11.                                     .list(); 
  12.                             totalCount += Long.parseLong(countlist.get(0
  13.                                     .toString()); 
  14.                         } else
  15.                             totalCount = total; 
  16.                         } 
  17.  
  18.                         if (totalCount < 1) { 
  19.                             return new Page(); 
  20.                         } 
  21.  
  22.                         // 实际查询返回分页对象 
  23.                         Query query = session 
  24.                                 .createSQLQuery(resultSql) 
  25.                                 .addScalar("carLsh", Hibernate.INTEGER) 
  26.                                 .addScalar("carPic", Hibernate.STRING) 
  27.                                 .addScalar("carInfo", Hibernate.STRING) 
  28.                                 .addScalar("carColor", Hibernate.STRING) 
  29.                                 .addScalar("carType", Hibernate.STRING) 
  30.                                 .setResultTransformer( 
  31.                                         Transformers.aliasToBean(CarInfo.class)); 
  32.  
  33.                         if (pageSize > 0) { 
  34.                             if (startIndex < 0) { 
  35.                                 query.setFirstResult(0); 
  36.                             } else if (startIndex >= totalCount) { 
  37.                                 return new Page(); 
  38.                             } else
  39.                                 query.setFirstResult(startIndex); 
  40.                             } 
  41.  
  42.                             if (startIndex + pageSize > totalCount) { 
  43.                                 query.setMaxResults((int) totalCount 
  44.                                         - startIndex); 
  45.                             } else
  46.                                 query.setMaxResults(pageSize); 
  47.                             } 
  48.  
  49.                         } 
  50.                         return new Page(startIndex, totalCount, pageSize, query 
  51.                                 .list()); 
  52.                     } 
  53.                 }); 
  54.         return result; 
  55.     } 

目录
相关文章
|
4月前
|
存储 NoSQL Java
Spring Session框架
Spring Session 是一个用于在分布式环境中管理会话的框架,旨在解决传统基于 Servlet 容器的会话管理在集群和云环境中的局限性。它通过将用户会话数据存储在外部介质(如数据库或 Redis)中,实现了会话数据的跨服务器共享,提高了应用的可扩展性和性能。Spring Session 提供了无缝集成 Spring 框架的 API,支持会话过期策略、并发控制等功能,使开发者能够轻松实现高可用的会话管理。
Spring Session框架
|
6月前
|
存储 安全 Java
实现基于Spring Cloud的分布式配置管理
实现基于Spring Cloud的分布式配置管理
|
7月前
|
JSON Java 数据格式
Spring Boot 中的 @DateTimeFormat 和 @JsonFormat 的用法及作用
【6月更文挑战第11天】在开发 Spring Boot 应用时,处理日期和时间数据是一个常见的需求。Spring Boot 提供了两个注解 @DateTimeFormat 和 @JsonFormat 来帮助我们处理这些问题。
540 4
|
7月前
|
前端开发 Java 开发者
深入理解 Spring Boot 注解:核心功能与高级用法详解
深入理解 Spring Boot 注解:核心功能与高级用法详解
417 1
|
7月前
|
监控 Java UED
Java一分钟之-Spring Cloud Netflix Hystrix:容错管理
【6月更文挑战第9天】Spring Cloud Hystrix是用于微服务容错管理的库,通过断路器模式防止服务雪崩。本文介绍了Hystrix的基本概念,如断路器、线程隔离和fallback机制,并展示了如何快速上手,包括添加依赖、启用注解和编写Hystrix命令。此外,还讨论了常见问题(如断路器打开、资源泄漏和不当的Fallback策略)及其解决方案。通过自定义Hystrix指标监控,可以进一步优化系统性能。理解Hystrix工作原理并适时调整配置,对于构建健壮的微服务至关重要。
239 3
|
6月前
|
安全 Java Spring
Spring Boot中的环境配置和管理
Spring Boot中的环境配置和管理
|
7月前
|
JSON 前端开发 Java
Spring第一课,了解IDEA里面的文件,回顾Cookie和Session,获取Session,Cookie,Header的方式
Spring第一课,了解IDEA里面的文件,回顾Cookie和Session,获取Session,Cookie,Header的方式
|
6月前
|
Java 开发工具 git
Spring Cloud中的分布式配置管理
Spring Cloud中的分布式配置管理
|
6月前
|
缓存 监控 Java
Spring Boot中使用Ehcache进行缓存管理
Spring Boot中使用Ehcache进行缓存管理
|
6月前
|
Java 开发工具 数据安全/隐私保护
Spring Cloud中的分布式配置管理最佳实践
Spring Cloud中的分布式配置管理最佳实践