依赖注入
python
<dependencies>
<!-- Spring常用依赖 -->
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-context</artifactId>
<version>5.2.8.RELEASE</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-aspects</artifactId>
<version>5.2.8.RELEASE</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-tx</artifactId>
<version>5.2.8.RELEASE</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-jdbc</artifactId>
<version>5.2.8.RELEASE</version>
</dependency>
<!-- MySql -->
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>5.1.47</version>
</dependency>
<!--连接池-->
<dependency>
<groupId>com.alibaba</groupId>
<artifactId>druid</artifactId>
<version>1.1.0</version>
</dependency>
<!--mybatis-->
<dependency>
<groupId>org.mybatis</groupId>
<artifactId>mybatis</artifactId>
<version>3.5.3</version>
</dependency>
<dependency>
<groupId>org.mybatis</groupId>
<artifactId>mybatis-spring</artifactId>
<version>2.0.3</version>
</dependency>
<!--日志-->
<dependency>
<groupId>org.slf4j</groupId>
<artifactId>slf4j-log4j12</artifactId>
<version>1.7.26</version>
</dependency>
<!--junit-->
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-test</artifactId>
<version>5.2.8.RELEASE</version>
</dependency>
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>4.12</version>
</dependency>
</dependencies>
<build>
<resources>
<resource>
<directory>src/main/java</directory>
<includes>
<include>**/*.xml</include>
</includes>
</resource>
<resource>
<directory>src/main/resources</directory>
</resource>
</resources>
</build>
依赖注入后接下来的是创建dao,service,Mapper文件夹

创建好接下来是把properties文件写入applicationContext.xml文件中
一,Spring 自动扫描指定包下所有带注解的类
python
<!--IOC-->
//开启 Spring 组件扫描
//Spring IOC 容器自动扫描指定包下的所有类
<context:component-scan base-package="com.yunkukukukuku"/>
二,读取配置文件
python
<!--引入db.properties-->
<context:property-placeholder location="classpath:db.properties"/>
三,加载类路径下的 db.properties 配置文件
python
<!--数据源-->
//${...} 从 db.properties 读取配置
//destroy-method="close":Spring 关闭时自动关闭连接池,释放资源
<bean id="dataSource" class="com.alibaba.druid.pool.DruidDataSource" destroy-method="close">
<property name="driverClassName" value="${jdbc.driverClass}"></property>
<property name="url" value="${jdbc.url}"></property>
<property name="username" value="${jdbc.username}"></property>
<property name="password" value="${jdbc.password}"></property>
</bean>
四,配置 MyBatis 的核心:SqlSessionFactory
python
<!--sqlSessionFactory-->
//SqlSessionFactory 是 MyBatis 核心,用来创建 SqlSession(操作数据库的会话)
<bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
<property name="dataSource" ref="dataSource"></property>
</bean>
五 扫描 Mapper 接口,生成代理类
python
<!--告诉mybatis要扫描的包:生成mapper接口的代理类,并交给spring的iocMap去管理-->
<bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
<property name="basePackage" value="com.yunkukukukuku.Mapper"></property>
<property name="sqlSessionFactoryBeanName" value="sqlSessionFactory"></property>
</bean>
六配置mapper.xml
python
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper
PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<!--配置-->
<mapper namespace="com.yunkukukukuku.Mapper.UserMapper">
<insert id="addUser" parameterType="com.yunkukukukuku.pojo.User">
insert into t_user(name,money) values(#{name},#{money})
</insert>
</mapper>
七,实现userService接口

八,在测试类中测试结果

九,总结内容
1,为什么可以在测试类当中可以使用@Autowired
python
Spring 整合 JUnit 单元测试 的固定标配,
@RunWith(SpringJUnit4ClassRunner.class) //junit运行时带上spring的环境
@ContextConfiguration("classpath:applicationContext.xml")

RunWith:RunWith 启动 Spring 容器--->加载SpringJUnit4ClassRunner(载配置文件,创建所有 bean:Service、Mapper、DataSource...)
加载后测试类才知道加载spring文件
ContextConfiguration 告诉 Spring 配置在哪
扩充:测试类本身,也会被 Spring 当成一个 Bean 来创建、管理!