1. 加载资源文件
      1. <!--加载资源文件-->
      2. <context:property-placeholder location="classpath:jdbc.properties"/>
    1. pom.xml导入druid和mybatis-spring依赖 ```xml com.alibaba druid 1.1.17

    org.mybatis mybatis-spring 2.0.5

    
    
    3. 
    beans.xml中添加数据源bean(druid连接池)
    ```xml
    <!-- 数据源 -->
    <bean id="dataSource" class="com.alibaba.druid.pool.DruidDataSource">
        <!-- 数据库驱动 -->
        <property name="driverClassName" value="${driverClassName}"/>
        <!-- 数据库访问地址 -->
        <property name="url" value="${url}"/>
        <!-- 账号 -->
        <property name="username" value="${username}"/>
        <!-- 密码 -->
        <property name="password" value="${password}"/>
    
    
        <!-- 初始连接数 -->
        <property name="initialSize" value="5"/>
        <!-- 最大活动连接数 -->
        <property name="maxActive" value="20"/>
        <!-- 最小连接数 -->
        <property name="minIdle" value="5"/>
        <!-- 最大等待获取连接时间 -->
        <property name="maxWait" value="5000"/>
    
    </bean>
    
    1. beans.xml导入mybatis-spring的前缀
      <?xml version="1.0" encoding="UTF-8"?>
      <beans xmlns="http://www.springframework.org/schema/beans"
          xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
          xmlns:context="http://www.springframework.org/schema/context"
          xmlns:aop="http://www.springframework.org/schema/aop"
          xmlns:mybatis="http://mybatis.org/schema/mybatis-spring"
          xsi:schemaLocation="http://www.springframework.org/schema/beans
           https://www.springframework.org/schema/beans/spring-beans.xsd
           http://www.springframework.org/schema/context
           http://www.springframework.org/schema/context/spring-context.xsd
           http://www.springframework.org/schema/aop
           http://www.springframework.org/schema/aop/spring-aop.xsd
           http://mybatis.org/schema/mybatis-spring
           http://mybatis.org/schema/mybatis-spring.xsd">
      
    1. beans.xml bean标签导入mybatis-spring下的类SqlSessionFactory,并赋给其dataSource数据源
      <!-- SqlSessionFactory -->
      <bean id="sessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
       <property name="dataSource" ref="dataSource"/>
      </bean>
      
    1. mybatis-spring前缀有扫描功能,开始扫描mybatis映射器
      <!-- 扫描mybatis映射器 -->
      <mybatis:scan base-package="com.jie.ssm.dao"/>
      
    1. pom.xml导入spring-test依赖
      <!-- spring test -->
      <dependency>
      <groupId>org.springframework</groupId>
      <artifactId>spring-test</artifactId>
      <version>${spring.version}</version>
      </dependency>
      
    1. 在beans.xml的sessionFactory bean下添加别名
      <!-- SqlSessionFactory -->
      <bean id="sessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
       <property name="dataSource" ref="dataSource"/>
       <!--此包下添加别名,默认-->
       <property name="typeAliasesPackage" value="com.jie.ssm.entity"/>
      </bean>
      
    1. 遇到的第一个坑 ```xml  在配置项目中,spring读取jdbc.properties文件连接mysql时报错: java.sql.SQLException: Access denied for user ‘Administrator’@’localhost’ (using password: YES)

      很奇怪这里spring的配置是

    1 2 3 4   jdbc.properties配置是

    driver=com.mysql.jdbc.Driver url=jdbc:mysql://127.0.0.1:3306/sems?useUnicode=true&characterEncoding=utf8 username=root password=root   根据报错信息,spring读取到的username 是 ‘Administrator’。手动更改${username}为root时连接成功。说明这里${username}读取成了别的属性值,这里根据报错信息的Administrator判断应该是读取到了本机的名称.。换个属性名称就OK了

      将jdbc.properties的username改为jdbc.username,同时更改spring中的配置,重启测试,成功连接。希望对遇到同样问题的同学们有所帮助。

    
    
    10. 
    Spring中事务
    
       1. 
    用异常看是否可以有事务的效果
    
          - 
    UserServiceImpl
    ```java
    @Override
    public void txTest() {
    
        userDao.delete(29);
    
        int i = 1/0;
    
        User user = new User();
        user.setId(System.currentTimeMillis());
        user.setUsername("张三");
        user.setGender("男");
        user.setAge(18);
        user.setAddress("hhh");
        user.setUsername("san.zhang");
        user.setPassword("123");
        userDaoinsert(user);
    }
    
      - 
    

    测试类

    package com.jie.ssm.service;
    
    
    import com.jie.ssm.dao.UserDao;
    import org.junit.Test;
    import org.junit.runner.RunWith;
    import org.springframework.beans.factory.annotation.Autowired;
    import org.springframework.test.context.ContextConfiguration;
    import org.springframework.test.context.junit4.SpringJUnit4ClassRunner;
    
    @RunWith(SpringJUnit4ClassRunner.class)//spring-test测试方法
    @ContextConfiguration(locations = {"classpath:beans.xml"})//告诉配置文件在哪
    public class UserServiceTest {
    
        @Autowired
        private UserService userService;
    
        @Test
        public void selectUsers(){
            userService.txTest();
        }
    }
    
         - 结果是可以删除,但异常后的代码无法生效
    
    1. beans.xml配置事务

      1. 事务管理器DataSourceTransactionManager
        <!-- 事务管理器 -->
        <bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
        <property name="dataSource" ref="dataSource"/>
        </bean>
        
      2. 
    

    引入前缀tx

    <?xml version="1.0" encoding="UTF-8"?>
    <beans xmlns="http://www.springframework.org/schema/beans"
           xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
           xmlns:context="http://www.springframework.org/schema/context"
           xmlns:aop="http://www.springframework.org/schema/aop"
           xmlns:tx="http://www.springframework.org/schema/tx"
           xmlns:mybatis="http://mybatis.org/schema/mybatis-spring"
           xsi:schemaLocation="http://www.springframework.org/schema/beans
            https://www.springframework.org/schema/beans/spring-beans.xsd
            http://www.springframework.org/schema/context
            http://www.springframework.org/schema/context/spring-context.xsd
            http://www.springframework.org/schema/aop
            http://www.springframework.org/schema/aop/spring-aop.xsd
            http://www.springframework.org/schema/tx
            http://www.springframework.org/schema/tx/spring-tx.xsd
            http://mybatis.org/schema/mybatis-spring
            http://mybatis.org/schema/mybatis-spring.xsd">
    
      3. 
    

    配置事务

         - 
    

    事务的属性

    1.事务传播性(propagation)
         REQUIRED(默认):如果有事务,则在事务中运行,否则创建新事务
         SUPPORTS:如果有事务,则在事务中运行,则非事务方式运行
         MANDATORY:必须在事务中运行,如果没有事务则会抛异常
         REQUIRES_NEW:挂起当前事务,创建新事务
         NOT_SUPPORTED:挂起当前事务,以非实物的方式运行
         NEVER:无需事务,如果有事务的话就会抛异常
         NESTED:支持事务嵌套
    
    2.事务隔离性(isolation)
         DEFAULT:使用数据库事务隔离级别
         READ_UNCOMMITTED:读,未提交,允许当前事务读取另一个尚未提交的事务,会出现脏读,不可重复读,幻读的情况
         READ_COMMITTED:读已提交,只能读取已经进行事务提交的数据,可以避免脏读,但是没解决不可重复读(另一个事务修改导致)和幻读
         REPEATABLE_READ:可重复读,避免脏读和不可重复读,没有解决幻读(另一个事务新增导致的)
         SERIALIZABLE:串行化,事务串行执行
    
    3.只读(read-only):true and false
    
    4.回滚:rollback-for
         rollback-for="java.lang.Exception":发生异常进行回滚,可以指定具体的异常
    
         - 
    

    配置事务

    <tx:advice id="txAdvice" transaction-manager="transactionManager">
        <tx:attributes>
            <tx:method name="get*" propagation="SUPPORTS" />
            <tx:method name="find*" propagation="SUPPORTS"/>
            <tx:method name="query*" propagation="SUPPORTS"/>
            <tx:method name="*" propagation="SUPPORTS" isolation="REPEATABLE_READ" rollback-for="java.lang.Exception"/>
        </tx:attributes>
    </tx:advice>
    
      4. 
    

    配置事务切面

    <!-- 配置事务切面 -->
    <aop:config>
        <!-- 通过AspectJ表达式配置切点,声明哪些类哪些方法需要事务 -->
        <aop:pointcut id="txPointcut" expression="execution(* com.jie.ssm.service..*.*(..))"/>
        <!-- AOP = Advice + Pointcut -->
        <aop:advisor advice-ref="txAdvice" pointcut-ref="txPointcut"/>
    </aop:config>
    
         - 事务开启成功,测试类测试的service里的方法具有事务特征