不得不说,spring+Hibernate 还是适合一些简单的项目。学了下mybatis。区别说大不大,说小不小。就不在这儿赘述了。今天就把spring+Hibernate的配置记录一下。以便了解更多的东西。
1.Hibernate的功能是连接数据库。通过连接池连接数据库。与spring配置的话,就是做一个连接连接池的作用。
2.spring 的功能是控制反转跟依赖注入。与Hibernate框架使用的话,就是处理事务做切点。不用连接数据库了。
3.整合一下,就是Hibernate跟spring都舍弃了那个比较薄弱的环节,发挥他们的特长。
下边记录一下配置:
1.在配置spring的xml文件中,第一部分是命名空间。导入命名空间要会自己去找。上网搜有可能不合适。也有可能找的慢。总的不如说直接在jar包中弄出来。
2.第二部分,我导入的是dao层的配置文件,另外创建了一个文件,在此文件中做了一个导入: <import resource="app-dao.xml"/>
3.注解扫描 <context:component-scan base-package="com.qianhui.qidss"></context:component-scan>
4.添加数据员的properties。如果你直接在第5部分,中的配置时候,连接数据库的部分的值为实际值的话,那就不需要第4部分的配置了
5.配置数据源:数据源的基本信息,以及你想要的配置:
<!-- 配置数据源 -->
<bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource">
<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.initialPoolSize}"></property>
<property name="maxPoolSize" value="${jdbc.maxPoolSize}"></property>
<property name="idleConnectionTestPeriod" value="18000"></property>
<property name="testConnectionOnCheckin" value="true"></property>
<property name="testConnectionOnCheckout" value="true"></property>
</bean>
6.配置sessionFactory:
<bean id="sessionFactory" class="org.springframework.orm.hibernate4.LocalSessionFactoryBean">
<!-- 配置数据源属性 -->
<property name="dataSource" ref="dataSource"></property>
<!-- 配置Hibernate映射文件的位置及名称,可以使用通配符 -->
<property name="mappingLocations" value="classpath:com/qianhui/qidss/entity/*.hbm.xml"></property>
<!-- 配置Hibernate的常用属性 -->
<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>
<prop key="hibernate.autoReconnect">true</prop>
</props>
</property>
</bean>
7.配置事务管理器,如果事务不是正确提交的话,就回滚。
<!-- 配置Hibernate的事务管理器 -->
<bean id="transactionManager" class="org.springframework.orm.hibernate4.HibernateTransactionManager">
<property name="sessionFactory" ref="sessionFactory"></property>
</bean>
<!-- 配置事务属性 ,需要事务管理器-->
<tx:advice id="txAdvice" transaction-manager="transactionManager">
<tx:attributes>
<tx:method name="get*" read-only="true"/>
<tx:method name="*"/>
</tx:attributes>
</tx:advice>
<!-- 配置事务切点,并把切点和事务关联起来 -->
<!-- <aop:pointcut expression="execution(* com.qianhui.qidss.services.impl.*.*(..))"
id="txPointcut"/>-->
<aop:config>
<aop:pointcut expression="execution(* com.qianhui.qidss.*.*.*.*(..))"
id="txPointcut"/>
<aop:advisor advice-ref="txAdvice" pointcut-ref="txPointcut"/>
</aop:config>
以上是基本的配置。不详细说了。拿这这个去配置多个数据库连接的示例。