spring整合hibernate包括三部分:hibernate的配置、hibernate核心对象交给spring管理、事务由AOP控制 好处:

  • 由java代码进行配置,摆脱硬编码,连接数据库等信息更灵活
  • session等生命周期得到更好的控制,session和事务依赖注入到DAO中,更爽
  • 事务由AOP管理更加清晰,自动管理事务

hibernate的配置

spring提供了一个sessionfactory的实现,LocalSessionFactoryBean 通过在LocalSessionFactoryBean中set值来达到配置的效果 注意,LocalSessionFactoryBean有几种:

  • org.springframework.orm.hibernate5.LocalSessionFactoryBean
  • org.springframework.orm.hibernate4.LocalSessionFactoryBean
  • org.springframework.orm.hibernate3.LocalSessionFactoryBean

他们的区别就是在不同版本的hibernate包中,根据自己的hibernate版本去选择

@Configuration
@PropertySource("classpath:/application.properties")
public class HibernateConf {
//Enviroment对象可以取到被@PropertySource标记的文件数据
//通过拿到properties文件中的属性来摆脱硬编码
@Autowired
public Environment env; //DataSource对象是用来配置连接数据库的信息
//在稍后配置LocalSessionFactoryBean会用到datasource来连接数据库
@Bean
public DataSource dataSource() throws ClassNotFoundException{
DataSource ds=new DataSource();
//通过Environment对象再Properties文件中拿到配置信息
ds.setUsername(env.getProperty("dataSource.username","root"));
ds.setPassword(env.getProperty("dataSource.password","null"));
ds.setAddress(env.getProperty("dataSource.address"));
ds.setDriver(env.getProperty("dataSource.driver"));
return ds;
} //LocalSessionFactoryBean同SessionBean
//用来配置hibernate
@Bean
@Autowired
public LocalSessionFactoryBean sessionFactory(DataSource dataSource){
LocalSessionFactoryBean sessionFactory=new LocalSessionFactoryBean();
sessionFactory.setDataSource(dataSource);
//设置扫描orm对象锁崽的包
sessionFactory.setPackagesToScan("weibo.po");
Properties prop=new Properties();
prop.setProperty("hibernate.dialect",env.getProperty("hibernate.dialect"));//设置hibernate方言
prop.setProperty("hibernate.show_sql", env.getProperty("hibernate.show_sql"));//设置显示sql
prop.setProperty("hibernate.format_sql",env.getProperty("hibernate.format_sql"));//格式化sql
prop.setProperty("hibernate.hbm2ddl.auto", env.getProperty("hibernate.hbm2ddl.auto"));//自动建表
sessionFactory.setHibernateProperties(prop);
return sessionFactory;
}

精髓是,摆脱硬编码,连接数据库的信息(username,password,driver,address....)通过spring提供的Enviroment对象去读取外置数据文件(application.properties)得到连接信息,这样子数据库配置就直接在application.properties中配置就可以了要注意的是,LocalSessionFactoryBean和SessionFactory并不是多态的关系,但是LocalSessionFactoryBean中持有一个SessionFactory对象,spring在运行期会自动实例化LocalSessionFactoryBean中的SessionFactory对象,所以我们从spring容器拿LocalSessionFactoryBean对象实际上是拿到了LocalSessionFactoryBean的SessionFactory

session等交给spring容器

把SessionFactory、Session、Transcation对象交给Spring容器管理

  • 更好的管理生命周期,避免资源浪费
  • 利用依赖注入,不再手动开启连接
  • 利用AOP管理事务,不再手动管理事务

SessionFactory在刚才配置hibernate的时候已经标识为Bean了,就不用再配置了

 //session
@Bean
//request作用域+通过类实现代理
@Scope(scopeName=WebApplicationContext.SCOPE_REQUEST,proxyMode=ScopedProxyMode.TARGET_CLASS)
//自动装配已经装配好的SessionFactory
@Autowired
public Session session(SessionFactory sessionFactory){
return sessionFactory.openSession();
} //transaction
@Bean
@Scope(scopeName=WebApplicationContext.SCOPE_REQUEST,proxyMode=ScopedProxyMode.TARGET_CLASS)
//自动装配已经装配好的Session
@Autowired
public Transaction transction(Session session){
return session.beginTransaction();
}

这里有几个需要注意的地方

  • 设置好scope,作用域一般都是request或者是session,避免长期连接数据库
  • 设置好代理,因为要将Session和Transcation注入DAO中,DAO一般都是单例的,而Session和事务是短作用域的。所以要使用代理对象先注入到DAO中,待使用时再调用真正对象
  • 通过已经装配好的SessionFactory来开启Session
  • 通过已经装配好的Session来开启事务(才能达到session和transcation对象一一对应)

事务通过AOP控制

当不用AOP的时候,我们会写这样的代码

 public void crud() throws SQLException{
try{
//操作数据库的代码
transaction.submit();//提交
}catch(SQLException e){
transaction.rollback();//回滚
throw e;
}finally{
session.close();//关闭连接
}
}

一般crud都需要有这几步:提交事务、出错时回滚事务、关闭连接

这种重复性,且无关业务逻辑的代码何不用aop完成呢

当通过AOP管理事务的时候只需要
  • 设置curd为切点
  • 在切点处写一个环绕通知,在环绕通知中实现事务的几个步骤
//声明切面
@Aspect
public class DAOAspect {
//自动装配session和transcation
@Autowired
private Session session;
@Autowired
private Transaction transaction;
//声明切点
@Pointcut("execution(* *.dao.*.crud(*))")//这样子所有dao包下的crud方法都会被标记为切点
public void crud(){} //在crud地方环绕通知
@Around("crud()")
public void aroundCrud(ProceedingJoinPoint p) throws Throwable{
try{
p.proceed();//执行crud动作
transaction.commit();//提交事务
}catch(Throwable e){
transaction.rollback();//出错回滚
throw e;
}finally{
session.close();//关闭连接
}
}
}
这样一看是不是方便多啦,从此事务管理只用写一次有几个需要注意的地方
  • p.proceed()一定要写,不写就不会调用切点(crud)的方法了,就像切点(crud)被拦截过滤了一样
  • throw e一定要写,因为aop实际就是一个代理对象,不然操作数据库错误了也不会抛出错误(错误被代理对象捕获catch处理了)
  • 不要在crud原方法中,提交事务、关闭连接了,不然aop层面会报错的(连接已关闭,事务已提交)
  • 因为session和transcation最小作用域都是请求级别的,所以不用担心自动装配进来的对象是不是原来那个
查看原文:http://zswlib.com/2016/07/14/spring%e6%95%b4%e5%90%88hibernate/

spring整合hibernate的更多相关文章

  1. 【Java EE 学习 53】【Spring学习第五天】【Spring整合Hibernate】【Spring整合Hibernate、Struts2】【问题:整合hibernate之后事务不能回滚】

    一.Spring整合Hibernate 1.如果一个DAO 类继承了HibernateDaoSupport,只需要在spring配置文件中注入SessionFactory就可以了:如果一个DAO类没有 ...

  2. spring整合hibernate的详细步骤

    Spring整合hibernate需要整合些什么? 由IOC容器来生成hibernate的sessionFactory. 让hibernate使用spring的声明式事务 整合步骤: 加入hibern ...

  3. spring 整合hibernate

    1. Spring 整合 Hibernate 整合什么 ? 1). 有 IOC 容器来管理 Hibernate 的 SessionFactory2). 让 Hibernate 使用上 Spring 的 ...

  4. Spring 整合 Hibernate

    Spring 整合 Hibernate •Spring 支持大多数流行的 ORM 框架, 包括 Hibernate JDO, TopLink, Ibatis 和 JPA. •Spring 对这些 OR ...

  5. 使用Spring整合Hibernate,并实现对数据表的增、删、改、查的功能

    1.1 问题 使用Spring整合Hibernate,并实现资费表的增.删.改.查. 1.2 方案 Spring整合Hibernate的步骤: 1.3 步骤 实现此案例需要按照如下步骤进行. 采用的环 ...

  6. Spring整合Hibernate详细步骤

    阅读目录 一.概述 二.整合步骤 回到顶部 一.概述 Spring整合Hibernate有什么好处? 1.由IOC容器来管理Hibernate的SessionFactory 2.让Hibernate使 ...

  7. SSH整合之spring整合hibernate

    SSH整合要导入的jar包: MySQL中创建数据库 create database ssh_db; ssh_db 一.spring整合hibernate带有配置文件hibernate.cfg.xml ...

  8. 【Spring】Spring系列6之Spring整合Hibernate

    6.Spring整合Hibernate 6.1.准备工作 6.2.示例 com.xcloud.entities.book com.xcloud.dao.book com.xcloud.service. ...

  9. 3、Spring整合Hibernate

    经过前面的两节分析:1.Hibernate之生成SessionFactory源码追踪 和 2.Spring的LocalSessionFactoryBean创建过程源码分析 .我们可以得到这样一个结论, ...

随机推荐

  1. 使用sklearn做单机特征工程

    目录 1 特征工程是什么?2 数据预处理 2.1 无量纲化 2.1.1 标准化 2.1.2 区间缩放法 2.1.3 标准化与归一化的区别 2.2 对定量特征二值化 2.3 对定性特征哑编码 2.4 缺 ...

  2. 导入一些常用命令比如(rz),关闭防火墙外面可以访问

     yum -y install lrzsz-----------导入常用命令 我在虚拟机上面启动了一个项目 这个原因是防火墙造成的,关闭防火墙  iptables -L 查看下 service ipt ...

  3. TSql 巧用Alt 键

    1,查看表的信息 在TSql 编辑器中,选中一个表,如图 点击Alt+F1,就可以查看表的属性定义 2,使用alt批量插入逗号 在Tsql中使用 in 子句,在(value_List)列表中,经常有很 ...

  4. 这台计算机上缺少此项目引用的 NuGet 程序包-缺少的文件是 ..\packages\Microsoft.CodeDom.Providers.DotNetCompilerPlatform.1.0.0\build\Microsoft.CodeDom.Providers.DotNetCompilerPlatform.props

    异常处理汇总-开发工具  http://www.cnblogs.com/dunitian/p/4522988.html 协助开发里面总有几个是极简爱好者,但是呢删了不该删的就会影响项目开发,下面看下完 ...

  5. WPF 浏览文件夹,获取其路径

    public void GetPath(System.Windows.Controls.TextBox TB) { FolderBrowserDialog FBD = new FolderBrowse ...

  6. 深入学习jQuery动画队列

    前面的话 队列实现是jQuery非常棒的一个拓展,使用动画队列可以使动画更容易实现.本文将详细介绍jQuery动画队列 queue() queue()方法用来显示在匹配的元素上的已经执行的函数队列 q ...

  7. alert()与console.log()的区别

    [1]alert() [1.1]有阻塞作用,不点击确定,后续代码无法继续执行 [1.2]alert()只能输出string,如果alert输出的是对象会自动调用toString()方法 e.g. al ...

  8. 交叉验证(Cross Validation)原理小结

    交叉验证是在机器学习建立模型和验证模型参数时常用的办法.交叉验证,顾名思义,就是重复的使用数据,把得到的样本数据进行切分,组合为不同的训练集和测试集,用训练集来训练模型,用测试集来评估模型预测的好坏. ...

  9. iOS开发之使用Storyboard预览UI在不同屏幕上的运行效果

    在公司做项目一直使用Storyboard,虽然有时会遇到团队合作的Storyboard冲突问题,但是对于Storyboard开发效率之高还是比较划算的.在之前的博客中也提到过,团队合作使用Storyb ...

  10. MySQL中RESET SLAVE和RESET MASTER的区别

    RESET SLAVE的语法如下: RESET SLAVE [ALL] [channel_option] channel_option: FOR CHANNEL channel 其中,channel_ ...