Mybatis与Spring集成

一. 添加相关依赖

1.1 添加spring相关依赖
详情见资料“spring.pom.txt”
spring.pom.txt:

<!--5.0.1.RELEASE有冲突-->
<spring.version>5.0.2.RELEASE</spring.version>

   <!-- ********************** spring依赖 ********************** -->
    <!--1)spring核心依赖-->
    <dependency>
        <groupId>org.springframework</groupId>
        <artifactId>spring-core</artifactId>
        <version>${spring.version}</version>
    </dependency>
    <!--spring ioc依赖 -->
    <dependency>
        <groupId>org.springframework</groupId>
        <artifactId>spring-beans</artifactId>
        <version>${spring.version}</version>
    </dependency>
    <!--spring 扩展依赖 -->
    <dependency>
        <groupId>org.springframework</groupId>
        <artifactId>spring-context</artifactId>
        <version>${spring.version}</version>
    </dependency>
    <!--2)spring dao层依赖-->
    <dependency>
        <groupId>org.springframework</groupId>
        <artifactId>spring-orm</artifactId>
        <version>${spring.version}</version>
    </dependency>
    <dependency>
        <groupId>org.springframework</groupId>
        <artifactId>spring-tx</artifactId>
        <version>${spring.version}</version>
    </dependency>
    <!--3)aop相关依赖 -->
    <dependency>
        <groupId>org.springframework</groupId>
        <artifactId>spring-aspects</artifactId>
        <version>${spring.version}</version>
    </dependency>
    <!--4)spring web相关依赖 -->
    <dependency>
        <groupId>org.springframework</groupId>
        <artifactId>spring-web</artifactId>
        <version>${spring.version}</version>
    </dependency>
    <!--5) spring test相关依赖 -->
    <dependency>
        <groupId>org.springframework</groupId>
        <artifactId>spring-test</artifactId>
        <version>${spring.version}</version>
    </dependency>
    <!--6)springMVC框架目前用不着,下门课程-->
    <!--<dependency>-->
    <!--<groupId>org.springframework</groupId>-->
    <!--<artifactId>spring-webmvc</artifactId>-->
    <!--<version>${spring.version}</version>-->
    <!--</dependency>-->

1.2 spring整合mybatis

org.mybatis
mybatis-spring
1.3.1

在这里插入图片描述

1.3 添加dbcp2连接池依赖

org.apache.commons
commons-dbcp2
2.1.1


org.apache.commons
commons-pool2
2.4.3

在这里插入图片描述

二. 创建spring配置文件spring.xml,并进行相关配置

在这里插入图片描述

  1. 注解式开发
    在这里插入图片描述
  2. 引入外置jdbc配置文件
    在这里插入图片描述
  3. dbcp2数据库连接池配置
    在这里插入图片描述
  4. spring和MyBatis整合
    整合之后Mybatis.cfg.xml可以删除了,因为都交给Spring管理了 在这里插入图片描述
  5. 注解式事务配置开始 在这里插入图片描述

spring.xml:

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
       xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
       xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd">
    <!--1. 引入外部properties文件 -->
    <bean id="propertyConfigurer"
          class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer">
        <property name="systemPropertiesModeName" value="SYSTEM_PROPERTIES_MODE_OVERRIDE" />
        <property name="ignoreResourceNotFound" value="true" />
        <property name="locations">
            <list>
                <value>classpath:jdbc.properties</value>
                <!--<value>classpath:config.properties</value>-->
                <!--<value>classpath:shiro-config.properties</value>-->
            </list>
        </property>
    </bean>

    <import resource="spring-mybatis.xml"/>
    <!--<import resource="spring-shiro.xml"/>-->
</beans>

spring-mybatis.xml:

<?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:tx="http://www.springframework.org/schema/tx"
       xmlns:aop="http://www.springframework.org/schema/aop"
       xsi:schemaLocation="http://www.springframework.org/schema/beans http://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/tx http://www.springframework.org/schema/tx/spring-tx.xsd http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop.xsd">

    <!--1. 注解式开发 -->
    <!--1) 注解驱动 -->
    <context:annotation-config/>
    <!--2) 用注解方式注入bean,并指定查找范围:com.zking.ssm及子子孙孙包-->
    <context:component-scan base-package="com.zking.ssm"/>

    <!-- 已在spring.xml中配置,只能引入一次 -->
    <!--2. 引入外置jdbc配置文件 -->
    <!--<bean id="propertyConfigurer" class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer">-->
    <!--<property name="location" value="classpath:jdbc.properties"/>-->
    <!--</bean>-->

    <!--3. dbcp2数据库连接池配置-->
    <bean id="dataSource" class="org.apache.commons.dbcp2.BasicDataSource"
          destroy-method="close">
        <property name="driverClassName" value="${jdbc.driver}"/>
        <property name="url" value="${jdbc.url}"/>
        <property name="username" value="${jdbc.username}"/>
        <property name="password" value="${jdbc.password}"/>
        <!--初始连接数-->
        <property name="initialSize" value="3"/>
        <!--最大活动连接数-->
        <property name="maxTotal" value="10"/>
        <!--最大空闲连接数-->
        <property name="maxIdle" value="10"/>
        <!--最小空闲连接数-->
        <property name="minIdle" value="3"/>
        <!--设置为-1时,如果没有可用连接,连接池会一直无限期等待,直到获取到连接为止。-->
        <!--如果设置为N(毫秒),则连接池会等待N毫秒,等待不到,则抛出异常-->
        <property name="maxWaitMillis" value="-1"/>
    </bean>


    <!--4. spring和MyBatis整合 -->
    <!--1) 创建sqlSessionFactory-->
    <bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
        <!-- 指定数据源 -->
        <property name="dataSource" ref="dataSource"/>
        <!-- 指定mybatis核心配置文件 -->
        <!--<property name="configLocation" value="classpath:mybatis.cfg.xml"/>-->
        <!-- 自动扫描XxxMapping.xml文件,**任意路径 -->
        <property name="mapperLocations" value="classpath:mapper/*.xml"/>
        <!-- 指定别名 -->
        <property name="typeAliasesPackage" value="com.zking.oa.model"/>
        <!--setting设置:日志、二级缓存-->
        <property name="configuration">
            <bean class="org.apache.ibatis.session.Configuration">
                <property name="logImpl">
                    <value>org.apache.ibatis.logging.slf4j.Slf4jImpl</value>
                </property>
                <property name="cacheEnabled">
                    <value>true</value>
                </property>
            </bean>
        </property>
        <!--插件配置-->
        <property name="plugins">
            <list>
                <!--分页插件-->
                <bean class="com.github.pagehelper.PageInterceptor">
                    <property name="properties">
                        <props>
                            <!--分页合理化-->
                            <prop key="reasonable">true</prop>
                            <!--当设置为true的时候,如果pagesize设置为0-->
                            <prop key="pageSizeZero">true</prop>
                            <!--是否支持接口参数来传递分页参数,默认false-->
                            <prop key="supportMethodsArguments">true</prop>
                            <!--指定数据库-->
                            <prop key="helperDialect">mysql</prop>
                        </props>
                    </property>
                </bean>
            </list>
        </property>
    </bean>
    <!--2) 自动扫描com/zking/oa/**/mapper下的所有XxxMapper接口(其实就是DAO接口),并实现这些接口,-->
    <!--   即可直接在程序中使用dao接口,不用再获取sqlsession对象-->
    <bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
        <!--basePackage 属性是映射器接口文件的包路径。-->
        <!--你可以使用分号或逗号 作为分隔符设置多于一个的包路径-->
        <property name="basePackage" value="com/zking/oa/**/mapper"/>
        <property name="sqlSessionFactoryBeanName" value="sqlSessionFactory"/>
    </bean>

    <!--5. 注解式事务配置开始 -->
    <!--1) 事务管理器 -->
    <bean id="transactionManager"
          class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
        <property name="dataSource" ref="dataSource"/>
    </bean>
    <!--2) 开启事务注解 -->
    <tx:annotation-driven transaction-manager="transactionManager"/>
    <!-- 注解式事务配置结束 -->

    <!--6) 开启自动代理 -->
    <aop:aspectj-autoproxy/>
</beans>

jdbc.properties:

jdbc.driver=com.mysql.jdbc.Driver
jdbc.url=jdbc:mysql://localhost:3306/hjj?useUnicode=true&characterEncoding=utf8
jdbc.username=root
jdbc.password=123

注:还可以在idea中添加对spring开发的支持:Project Structure --> Facets --> Spring

三. 注解式开发

@Component(组件) 在这里插入图片描述在这里插入图片描述
@Scope
在这里插入图片描述
@Repository(持久层)
@Service(业务层)
@Constroller(控制层)

@Autowired 在这里插入图片描述
@Resource
在这里插入图片描述
@Transactional
在这里插入图片描述

注1:各个注解的作用请参考资料“注解式开发

四. Spring Test+JUnit完美组合

4.1 在工程的pom文件中增加spring-test的依赖

  <dependency>
   <groupId>org.springframework</groupId>
   <artifactId>spring-test</artifactId>
   <version>${spring.version}</version>
  </dependency>

在这里插入图片描述

4.2 创建BaseTestCase,并在该类上加上两个注解:

  @RunWith(SpringJUnit4ClassRunner.class)
  @ContextConfiguration(locations={"classpath:spring.xml"})

在这里插入图片描述

4.3 修改测试类,去掉繁琐的代码:
在这里插入图片描述

五. 修改分页代码:

使用AOP编程解决分页代码重复的问题
注1:AOP注解式开发详情见资料“Spring如何实现AOP环绕通知.mht”
注2:AOP分页实现“PageBeanAspect.java”
在这里插入图片描述
在这里插入图片描述
PageBeanAspect.java:

package com.zking.ssm.util;

import com.github.pagehelper.PageHelper;
import com.github.pagehelper.PageInfo;
import org.aspectj.lang.ProceedingJoinPoint;
import org.aspectj.lang.annotation.Around;
import org.aspectj.lang.annotation.Aspect;
import org.springframework.stereotype.Component;

import java.util.List;

/**
 * aop环绕通知,在*Biz.list*()方法前后执行,与mybatis的PageHelper插件一起完成PageBean的初始化
 *
 * @author Administrator
 */
@Component
@Aspect
public class PageBeanAspect {

    @Around(value = "execution(* *..*Service.list*(..))")//自动在Service查找需要过滤的方法名
    public Object invoke(ProceedingJoinPoint joinPoint) throws Throwable {
        // 取出PageBean
        Object[] args = joinPoint.getArgs();
        PageBean pageBean = null;
        for (Object obj : args) {
            if (obj instanceof PageBean) {
                pageBean = (PageBean) obj;
                break;
            }
        }

        // 如果分页,指定分页参数
        if (null != pageBean && pageBean.isPagination()) {
            PageHelper.startPage(pageBean.getPage(), pageBean.getRows());
        }

        Object returnValue = joinPoint.proceed(args);

        // 如果分页,获得总记录数
        if (null != pageBean && pageBean.isPagination() && null != returnValue &&
                returnValue instanceof List) {
            List list = (List) returnValue;
            PageInfo pageInfo = new PageInfo(list);
            Long total = pageInfo.getTotal();
            pageBean.setTotal(total.intValue());
        }

        return returnValue;
    }
}

整合完成(测试结果):
在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值