spring+hibernate 两种整合方式配置文件的方法

作者:QH_JAVA 时间:2022-02-27 21:36:47 

之前的文章都是讲解springmvc+spring+mybatis 的整合,而很少有springmvc+spring+hibernate 因为工作的需要,最近在使用hibernate 所以下面我们来看看 spring整合hibernate的配置文件,这里只说spring+hibernate 的配置文件而不说springmvc 因为这些是不用变的。

spring整合hibernate 有两种方式 1、注解方式 2、xml方式实现

1、注解方式实现:

applicationContext.xml配置文件:


<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
  xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
  xmlns:aop="http://www.springframework.org/schema/aop"
  xmlns:tx="http://www.springframework.org/schema/tx"
  xmlns:context="http://www.springframework.org/schema/context"
  xsi:schemaLocation="
    http://www.springframework.org/schema/beans
    http://www.springframework.org/schema/beans/spring-beans.xsd
    http://www.springframework.org/schema/tx
    http://www.springframework.org/schema/tx/spring-tx.xsd
    http://www.springframework.org/schema/aop
    http://www.springframework.org/schema/aop/spring-aop.xsd
    http://www.springframework.org/schema/context
    http://www.springframework.org/schema/context/spring-context.xsd">
 <context:component-scan base-package="com.test" />
 <bean class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer">
  <property name="locations">
   <list>
     <value>classpath:jdbc.properties</value>
   </list>
  </property>
 </bean>
 <bean id="c3p0DataSource" destroy-method="close"
   class="com.mchange.v2.c3p0.ComboPooledDataSource">
   <property name="driverClass" value="${driverClass}" />
   <property name="jdbcUrl" value="${url}" />
   <property name="user" value="${user}" />
   <property name="password" value="${password}" />
   <property name="initialPoolSize" value="${initialPoolSize}" />
   <property name="minPoolSize" value="${minPoolSize}" />
   <property name="maxPoolSize" value="${maxPoolSize}" />
   <property name="maxIdleTime" value="${maxIdleTime}" />
 </bean>          
 <bean id="sessionFactory"
   class="org.springframework.orm.hibernate4.LocalSessionFactoryBean">
   <property name="dataSource" ref="c3p0DataSource" />
   <property name="packagesToScan">
     <list>
       <value>com.test.bean</value>
     </list>
   </property>
   <property name="hibernateProperties">
     <props>
       <prop key="hibernate.dialect">${dialect}</prop>
       <prop key="hibernate.show_sql">${show_sql}</prop>
       <prop key="hibernate.format_sql">${format_sql}</prop>
       <prop key="hibernate.use_sql_commants">${use_sql_comments}</prop>
       <prop key="hibernate.hbm2ddl.auto">${hbm2ddl.auto}</prop>
     </props>
   </property>
 </bean>
 <bean id="txManager"
   class="org.springframework.orm.hibernate4.HibernateTransactionManager">
   <property name="sessionFactory" ref="sessionFactory" />
 </bean>
 <tx:advice id="txAdvice" transaction-manager="txManager">
   <tx:attributes>
     <tx:method name="get*" read-only="true" />
     <tx:method name="*" />
   </tx:attributes>
 </tx:advice>
 <aop:config>
   <aop:pointcut id="bizMethods" expression="execution(* com.test.biz.*.*(..))" />
   <aop:advisor advice-ref="txAdvice" pointcut-ref="bizMethods" />
 </aop:config>
</beans>

2.xml方式实现

applicationContext.xml配置:


<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:aop="http://www.springframework.org/schema/aop"
xmlns:tx="http://www.springframework.org/schema/tx"
xsi:schemaLocation="http://www.springframework.org/schema/beans
          http://www.springframework.org/schema/beans/spring-beans.xsd
          http://www.springframework.org/schema/tx
          http://www.springframework.org/schema/tx/spring-tx.xsd
          http://www.springframework.org/schema/aop
          http://www.springframework.org/schema/aop/spring-aop.xsd">

<!-- 让spring 去读取指定路径下的资源文件 -->
 <bean class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer">
  <property name="locations" value="classpath:jdbc.properties"/>
 </bean>

<!-- 配置c3p0连接池 -->
 <bean id="c3p0Source" class="com.mchange.v2.c3p0.ComboPooledDataSource" destroy-method="close">
  <property name="driverClass" value="${driverClass}" />
  <property name="jdbcUrl" value="${url}" />
  <property name="user" value="${user}" />
  <property name="password" value="${password}" />
  <property name="initialPoolSize" value="${initialPoolSize}" />
  <property name="minPoolSize" value="${minPoolSize}" />
  <property name="maxPoolSize" value="${maxPoolSize}" />
  <property name="maxIdleTime" value="${maxIdleTime}" />
 </bean>

<!-- 配置SessionFactory -->
 <bean id="sessionFactory" class="org.springframework.orm.hibernate4.LocalSessionFactoryBean">
  <property name="dataSource" ref="c3p0Source" />
  <property name="mappingResources">
    <list>
     <value>/com/cdzg/spring/bean/User.hbm.xml</value>
    </list>
  </property>
  <property name="hibernateProperties">
   <props>
       <prop key="hibernate.dialect">${dialect}</prop>
       <prop key="hibernate.hbm2ddl.auto">${hbm2ddl.auto}</prop>
       <prop key="hibernate.show_sql">${show_sql}</prop>
       <prop key="hibernate.format_sql">${format_sql}</prop>
       <prop key="hibernate.use_sql_comments">${use_sql_comments}</prop>
     </props>
  </property>
 </bean>

<!-- 配置事务管理器 -->
 <bean id="txManager" class="org.springframework.orm.hibernate4.HibernateTransactionManager">
  <property name="sessionFactory" ref="sessionFactory" />
 </bean>

<!-- 定义事务通知 -->
 <tx:advice id="txAdvice" transaction-manager="txManager">
  <tx:attributes>
   <tx:method name="get*" read-only="true"/>
   <tx:method name="*"/>
  </tx:attributes>
 </tx:advice>

<!-- 定义事务切面,并应用事务通知 -->  
  <aop:config>
  <aop:pointcut id="xxxBizImpl" expression="execution(* com.cdzg.spring.biz.*.*(..))"/>
  <aop:advisor pointcut-ref="xxxBizImpl" advice-ref="txAdvice"/>
  </aop:config>

<bean id="userDaoImpl" class="com.cdzg.spring.dao.impl.UserDaoImpl">
   <property name="sessionFactory" ref="sessionFactory" />
 </bean>
 <bean id="userBizImpl" class="com.cdzg.spring.biz.impl.UserBizImpl">
   <property name="userDao" ref="userDaoImpl" />
 </bean>
 <bean id="userAction" class="com.cdzg.spring.web.actions.UserAction">
   <property name="userBiz" ref="userBizImpl" />
 </bean>
</beans>

两种配置最大的区别就是注解方式不用在写O/R映射配置文件而xml方式实现的要配置O/R映射配置文件

spring+hibernate 两种整合方式配置文件的方法

注解的这种方式,直接扫描bean包就可以,剩下的对应关系由框架完成

spring+hibernate 两种整合方式配置文件的方法

而xml配置方式要配置O/R 映射文件并在这里指定文件,如果多的话可以使用通配符 "*"

来源:http://blog.csdn.net/qh_java/article/details/51824936

标签:spring,hibernate
0
投稿

猜你喜欢

  • Android自定义View实现课程表表格

    2023-03-11 19:33:08
  • android编程实现添加文本内容到sqlite表中的方法

    2023-07-09 06:59:13
  • android从资源文件中读取文件流并显示的方法

    2022-05-29 14:11:56
  • c# chart缩放,局部放大问题

    2021-09-26 20:46:40
  • Java开发druid数据连接池maven方式简易配置流程示例

    2021-05-26 14:57:23
  • SpringBoot实现MapperScan添加动态配置(占位符)

    2023-11-26 05:08:06
  • Spring Boot使用AOP实现REST接口简易灵活的安全认证的方法

    2023-04-10 04:38:44
  • android长截屏原理及实现代码

    2021-11-13 05:55:50
  • java 实现MD5加密算法的简单实例

    2023-07-19 21:53:56
  • 浅谈Java代理(jdk静态代理、动态代理和cglib动态代理)

    2023-06-09 18:57:49
  • mybatis-plus 新增/修改如何实现自动填充指定字段

    2023-11-28 22:20:53
  • Spring @CrossOrigin 注解原理实现

    2022-09-03 10:40:04
  • C#读写config配置文件的方法

    2023-11-17 02:30:17
  • java编程调用存储过程中得到新增记录id号的实现方法

    2022-06-09 02:55:52
  • Mybatis在sqlite中无法读写byte[]类问题的解决办法

    2021-08-06 21:06:07
  • springboot2.x整合tkmapper的示例代码

    2021-09-19 11:56:59
  • Android帧动画、补间动画、属性动画用法详解

    2023-02-06 15:02:47
  • FasfDFS整合Java实现文件上传下载功能实例详解

    2022-05-27 02:30:46
  • Java二维数组与动态数组ArrayList类详解

    2023-07-31 19:53:56
  • c# 颜色选择控件的实现代码

    2022-04-27 07:22:58
  • asp之家 软件编程 m.aspxhome.com