https://www.cnblogs.com/best/p/5648740.html
主要包括:
1、集成mybatis : MapperScanConfiger+SqlSessionFactoryBean
2、配置事务管理 : DatasourceTransactionManager(mybatis) + annotation-driven
3、IOC : component-scan
4、AOP : aspectj-autoproxy
具体配置:
<!--集成mybatis-->
<!--1 引入属性文件,在配置中占位使用 -->
<context:property-placeholder location="classpath*:db.properties" />
<!--2 配置C3P0数据源 -->
<bean id="datasource" class="com.mchange.v2.c3p0.ComboPooledDataSource" destroy-method="close">
<property name="driverClass" value="${jdbc.driver}" /> <!--驱动类名 -->
<property name=z"jdbcUrl" value="${jdbc.url}" />
<property name="user" value="${jdbc.uid}" />
<property name="password" value="${jdbc.pwd}" />
...
</bean>
<!--3 会话工厂bean sqlSessionFactoryBean -->
<bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
<property name="dataSource" ref="datasource"></property> <!-- 数据源 -->
<property name="typeAliasesPackage" value="com.zhangguo.bookstore.entities"></property> <!-- 实体类,起别名 -->
<property name="mapperLocations" value="classpath*:com/zhangguo/bookstore/mapper/*Mapper.xml"></property> <!-- sql映射文件路径 -->
</bean>
<!--4 自动扫描对象关系映射 -->
<bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
<!--指定会话工厂,如果当前上下文中只定义了一个则该属性可省去。可以不用指定,因为MapperScannerConfigurer会自动装配 -->
<property name="sqlSessionFactoryBeanName" value="sqlSessionFactory"></property>
<!-- 指定要自动扫描接口的基础包,实现接口 -->
<property name="basePackage" value="com.zhangguo.bookstore.mapper"></property>
</bean>
<!--5 声明式事务管理 -->
<!--定义事物管理器,由spring管理事务 -->
<bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
<property name="dataSource" ref="datasource"></property>
</bean>
<!--支持注解驱动的事务管理,指定事务管理器 -->
<tx:annotation-driven transaction-manager="transactionManager"/>
<!--6 容器自动扫描IOC组件 -->
<context:component-scan base-package="com.zhangguo.bookstore"></context:component-scan>
<!--7 aspectj支持自动代理实现AOP功能 -->
<aop:aspectj-autoproxy proxy-target-class="true"></aop:aspectj-autoproxy>
详解:
1、整合mybatis
1.1 SqlSessionFactoryBean 简介
1)与Spring集成。SqlSessionFactoryBean 实现了FactoryBean<SqlSessionFactory>,在配置为被Spring接管时,存入IOC容器中的实例类型将会是实例化泛型的那个类型,从IOC容器中获取时也是实例化泛型的那个类型,这种情况下,Spring 将会在应用启动时为你 创建SqlSessionFactory对象,然后将它以 SqlSessionFactory为名来存储。当把这个bean注入到Spring中去了以后,IOC容器中的其他类型就可以拿到SqlSession实例了,就可以进行相关的SQL执行任务了。
2)用于产生Mybatis全局性的会话工厂SqlSessionFactory(也就是产生会话工厂的工厂Bean),而SqlSessionFactory用于产生会话SqlSession对象(SqlSessionFactory相当于DataSource,SqlSession相当于Connection)。
其中属性(使用p命名空间或property子元素配置):
dataSource是数据源,可以使用DBCP、C3P0、Druid、jndi-lookup等多种方式配置
configLocation(typeAliases)是Mybatis引擎的全局配置,用于修饰Mybatis的行为
mapperLocations是Mybatis需要加载的SqlMapper脚本配置文件(模式)。
1.2 配置简介 Mybatis整合Spring -- typeAliasesPackage
在定义SqlSessionFactoryBean的时候,dataSource属性是必须指定的,它表示用于连接数据库的数据源。当然,我们也可以指定一些其他的属性,下面简单列举几个:
mapperLocations:它表示我们的Mapper文件存放的位置,当我们的Mapper文件跟对应的Mapper接口处于同一位置的时候可以不用指定该属性的值。
configLocation:用于指定Mybatis的配置文件位置。如果指定了该属性,那么会以该配置文件的内容作为配置信息构建对应的SqlSessionFactoryBuilder,但是后续属性指定的内容会覆盖该配置文件里面指定的对应内容。
typeAliasesPackage:它一般对应我们的实体类所在的包,这个时候会自动取对应包中不包括包名的简单类名作为包括包名的别名。多个package之间可以用逗号或者分号等来进行分隔。(value的值一定要是包的全名)
typeAliases:数组类型,用来指定别名的。指定了这个属性后,Mybatis会把这个类型的短名称作为这个类型的别名,前提是该类上没有标注@Alias注解,否则将使用该注解对应的值作为此种类型的别名。(value的值一定要是类的完全限定名)
即:typeAliasesPackage 、typeAliases设置这个以后再Mapper配置文件中在parameterType 的值就不用写成全路径名了ep:parameterType="com.bean.User"可以写成parameterType = "User"
1.3 多种配置案例
1)configuration.xml中配置
<bean id="sqlSessionFactory"class="org.mybatis.spring.SqlSessionFactoryBean">
<propertyname="dataSource" ref="dataSource" />
<propertyname="configLocation"value="classpath:mybatis/configuration.xml"/>
<propertyname="mapperLocations"value="classpath*:cn/edu/nuc/map/*.xml"/>
</bean>
configuration.xml:
<typeAliases>
<package name="com.ls.entity"/>
<package name="com.ls.domain"/>
</typeAliases>
2)支持多路径,逗号隔开SqlSessionFactoryBean">
<bean id="mybatisSqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
<property name="dataSource" ref="dataSource"/>
<property name="typeAliasesPackage" value="com.xiaomu.content.model, com.test.model"/> --支持多路径,逗号隔开
<property name="mapperLocations">
<list>
<value>classpath*:sql/**/*.xml</value>
</list>
</property>
</bean>
3) 若有新路径新增需要再次配置,不知情情况下容易疏漏,最好是通配符配置,目前不支持,可通过继承重写包路径读取方式来实现支持通配符配置
配置如下:
<bean id="mybatisSqlSessionFactory" class="com.xiaomu.jdbc.util.PackagesSqlSessionFactoryBean">
<property name="dataSource" ref="dataSource"/>
<property name="typeAliasesPackage" value="com.xiaomu.**.model"/> --通配符配置
<property name="mapperLocations">
<list>
<value>classpath*:sql/**/*.xml</value>
</list>
</property>
</bean>
1.3 MapperScannerConfigurer
1)不需要指定SqlSessionFactory 或SqlSessionTemplate,MapperScannerConfigurer 将会创建 MapperFactoryBean,之后自动装配;
2)MapperScannerConfigurer 其实和MapperFactoryBean类似,都是创建代理然后注入到spring中;区别是前者是自动扫描数据映射器接口,生成代理类、并注入到Spring的容器中;
我们这里不需要用MapperScannerConfigurer来创建MapperFactoryBean,以及生成代理类注入到spring中(后面的使用中会用到),我们需要:
1)需要MapperScannerConfigurer帮我们自动装配SqlSessionFactory 或 SqlSessionTemplate(因为SqlSessionDaoSupport 需要一个 sqlSessionFactory 或 sqlSessionTemplate属性来设置);
2)我们需要自己显示的在dao层加上@Component注解(否则依赖的时候会拿到注入到spring中的MapperScannerConfigurer生成的代理类)
3)dao层我们继承了SqlSessionDaoSupport,所以可以直接使用getSqlSession() 方法获取sqlSessionTemplate,然后操作数据映射文件(mapper文件)里的sql了;
https://www.cnblogs.com/jpfss/p/7799806.html
2、事务
2.1 架构详见:
https://www.jianshu.com/p/acf84a4ed3a3
2.2 配置(xml+注解)及注意事项详见:
https://www.cnblogs.com/dj66194/p/7654555.html
3、AOP
3.1 配置详解
https://www.cnblogs.com/qinglangyijiu/p/8425653.html
3.2 应用