<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:context="http://www.springframework.org/schema/context"
xmlns:p="http://www.springframework.org/schema/p"
xmlns:tx="http://www.springframework.org/schema/tx"
xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans-3.2.xsd
http://www.springframework.org/schema/aop
http://www.springframework.org/schema/aop/spring-aop-3.2.xsd
http://www.springframework.org/schema/context
http://www.springframework.org/schema/context/spring-context-3.2.xsd
http://www.springframework.org/schema/tx
http://www.springframework.org/schema/tx/spring-tx-3.2.xsd">
<!-- 1.开启扫描包中的注解 -->
<context:component-scan base-package="cn.smbms.service"/>
<!-- 2.引入database.properties 配置文件 -->
<!-- <bean class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer">
<property name="location">
<value>classpath:database.properties</value>
</property>
</bean> -->
<context:property-placeholder location="classpath:database.properties"/>
<!-- 3.创建dataSource数据源源 -->
<bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource">
<property name="driverClassName" value="${driver}"></property>
<property name="url" value="${url}"></property>
<property name="username" value="${user}"></property>
<property name="password" value="${password}"></property>
</bean>
<!-- 4.根据数据源创建sqlSessionFactoryBean -->
<bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
<property name="dataSource" ref="dataSource"></property>
<property name="configLocation" value="classpath:mybatis-config.xml"></property>
<!-- <property name="mapperLocations">
<list>
<value>classpath:cn/smbms/dao/*.xml</value>
</list>
</property>
<property name="typeAliasesPackage" value="cn.smbms.pojo"></property> -->
</bean>
<!-- 5.配置sql映射文件 -->
<bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
<property name="sqlSessionFactory" ref="sqlSessionFactory"></property>
<property name="basePackage" value="cn.smbms.dao"></property>
</bean>
<!-- 6.声明式事务处理 -->
<!-- 1.创建处理事务的BEAN -->
<bean id="txManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
<property name="dataSource" ref="dataSource"></property>
</bean>
<!-- 2.声明事务需要处理的规则 -->
<tx:advice id="txAdvice" transaction-manager="txManager">
<tx:attributes>
<tx:method name="add*" propagation="REQUIRED"/>
<tx:method name="find*" propagation="SUPPORTS"/>
</tx:attributes>
</tx:advice>
<!-- 3.织入事务处理 -->
<aop:config>
<aop:pointcut expression="execution(* cn.smbms.service..*.*(..))" id="point"/>
<aop:advisor advice-ref="txAdvice" pointcut-ref="point"/>
</aop:config>
<bean id="user" class="cn.smbms.pojo.User">
<property name="username" value="admin"></property>
<property name="usercode" value="admin123"></property>
<property name="password" value="123456"></property>
<property name="role" ref="role"></property>
</bean>
<bean id="role" class="cn.smbms.pojo.Role">
<property name="roleName" value="系统管理员"></property>
</bean>
</beans>
注释:
1、开启扫描包中的注解
<context:component-scan base-package="业务包">
2、引入database.properties 配置文件 bean config Configurer
<context:property-placeholder loacation="classpath:database.properties">
3、创建dataSource数据源
<bean id="dataSource" class="commons-dbcp包下的后缀commons 下的 BaseDataSource">
<property name="driverClassName" value="${(database.properties中的属性:)driver}">
.....
........
</bean>
4、根据数据源创建sqlSessionFactoryBean(工人创建工厂)
<bean id = "sqlSessionFactory" class="在mybatis-spring包下的 mybatis.spring 的SqlSessionFactoryBean">
映射第三部中的数据源dataSource(有了数据源才能进行加工操作)
<property name="dataSource" ref="数据源的id"></property>
配置从那里获取(从mybatis-config.xml)
<property name="configLocation" value="classpath:mybatis-config.xml"/>
</bean>
5、配置sql映射文件
<bean classs="(mybatis-spring下的后缀为mapper的包 下的 MapperScannerConfigurer)
org.mybatis.spring.mapper.MapperScannerConfigurer">
<property name ="sqlSessionFactory" ref="(映射创建的工厂)sqlSessionFactory">
<property name="basePackage(MapperScannerConfigurer里的)" value="cn.smbms.dao(映射的是cn.smbms.dao下的接口)">
</bean>
6、声明式事务处理
1、创建事务的bean
<bean id="txManager" class="(spring-jdbc下的后缀为jdbc.datasource包下的 DataSourceTransactionManager)
org.springframework.jdbc.datasource.DataSourceTransactionManager">
<property name="dataSource" ref="dataSource(引入第三步 数据源的 id)">
</bean>
2、声明 事务需要处理的规则(tx标签)
<tx:advice id="txAdvice" transaction-manager="txManager">
<tx:attributes>
定义规则
<tx:method name="add*" propagation="REQUIRED"/>
<tx:method name="find*" propagation="SUPPORTS"/>
</tx:attributes>
</tx:advice>
3、织入事务处理
<aop:config>
定义需要处理的方法<aop:pointcut expression="execution(* cn.smbms.service..*.*(..))" id="point"/>
用谁处理 处理谁<aop:advisor advice-ref="txAdvice(用谁处理)" pointcut-ref="point(处理谁)"/>
</aop:config>