Spring +Hibernate整合
首先先导入包,包导全了什么都好说。很多时候一些错误都是因为包不全导致的。
如图(SSH需要的包):
主要步骤
修改spring的ioc容器的相关配置
①编写数据源的资源文件(db.properties),放在src目录下。
jdbc.user=root
jdbc.password=root
jdbc.driverClass=com.mysql.cj.jdbc.Driver
jdbc.jdbcUrl=jdbc:mysql:///employee?serverTimezone=GMT%2b8&
jdbc.initPoolSize=50
jdbc.maxPoolSize=100
②导入资源文件并配置数据源,通过c3p0提供的ComboPooledDataSource进行配置数据库连接对象,链接相应的数据库。
<!-- 导入资源文件并配置数据源 -->
<context:property-placeholder location="classpath:db.properties"/>
<bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource" destroy-method="close">
<property name="user" value="${jdbc.user}"></property>
<property name="password" value="${jdbc.password}"></property>
<property name="driverClass" value="${jdbc.driverClass}"></property>
<property name="jdbcUrl" value="${jdbc.jdbcUrl}"></property>
<property name="initialPoolSize" value="${jdbc.initPoolSize}"></property>
<property name="maxPoolSize" value="${jdbc.maxPoolSize}"></property>
</bean>
③通过Spring提供的LocalSessionFactoryBean进行配置SessionFactory对象并引用连接池对象(注意映射文件的路径)。
<!-- 配置Hibernate的SessionFactory实例:通过 Spring提供的LocalSessionFactoryBean进行配置-->
<bean id="sessionFactory" class="org.springframework.orm.hibernate5.LocalSessionFactoryBean">
<property name="dataSource" ref="dataSource"></property>
<!--
<property name="configLocation" value="classpath:hibernate.cfg.xml"></property>
-->
<property name="hibernateProperties">
<props>
<prop key="hibernate.dialect">org.hibernate.dialect.MySQL5Dialect</prop>
<prop key="hibernate.show_sql">true</prop>
<prop key="hibernate.format_sql">true</prop>
<prop key="hibernate.hbm2ddl.auto">update</prop>
</props>
</property>
<property name="mappingLocations">
<list>
<value>classpath:com/bean/*.hbm.xml</value>
</list>
</property>
</bean>
④配置Spring的声明式事务:
(1)配置事务管理器
<!-- 1.配置事务管理器 -->
<bean id="transactionManager" class="org.springframework.orm.hibernate5.HibernateTransactionManager">
<property name="sessionFactory" ref="sessionFactory"></property>
</bean>
(2)配置事物属性,需要事务管理器
<!-- 2.配置事物属性,需要事务管理器 -->
<tx:advice id="txAdvice" transaction-manager="transactionManager">
<tx:attributes>
<tx:method name="*" read-only="false"/>
</tx:attributes>
</tx:advice>
(3)配置事物切点,并把切点和事物属性相关联
<!-- 3.配置事物切点,并把切点和事物属性相关联 -->
<aop:config proxy-target-class="true">
<aop:pointcut expression="execution(* com.qh.service.*.*(..))" id="txPointcut"/>
<aop:advisor advice-ref="txAdvice" pointcut-ref="txPointcut"/>
</aop:config>