Spring整合MyBatis的两种方式

Posted 我永远信仰

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Spring整合MyBatis的两种方式相关的知识,希望对你有一定的参考价值。


首先搭建一个Mybatis-spring的环境

【环境搭建】

步骤:

1.导入相关jar包

  • junit

  • mybatis

  • mysql数据库驱动

  • spring相关的

  • aop织入

  • mybatis-spring

<dependencies>
    <!--junit-->
    <dependency>
        <groupId>junit</groupId>
        <artifactId>junit</artifactId>
        <version>4.13</version>
        <scope>test</scope>
    </dependency>
    <!--mysql数据库驱动-->
    <dependency>
        <groupId>mysql</groupId>
        <artifactId>mysql-connector-java</artifactId>
        <version>5.1.6</version>
    </dependency>
    <!--mybatis-->
    <dependency>
        <groupId>org.mybatis</groupId>
        <artifactId>mybatis</artifactId>
        <version>3.5.6</version>
    </dependency>
    <!--spring相关的-->
    <dependency>
        <groupId>org.springframework</groupId>
        <artifactId>spring-webmvc</artifactId>
        <version>5.2.5.RELEASE</version>
    </dependency>
    <!--spring操作数据库的话,还需要一个jdbc-->
    <dependency>
        <groupId>org.springframework</groupId>
        <artifactId>spring-jdbc</artifactId>
        <version>5.2.5.RELEASE</version>
    </dependency>
    <!--aop织入-->
    <dependency>
        <groupId>org.aspectj</groupId>
        <artifactId>aspectjweaver</artifactId>
        <version>1.9.4</version>
    </dependency>
    <!--mybatis-spring-->
    <dependency>
        <groupId>org.mybatis</groupId>
        <artifactId>mybatis-spring</artifactId>
        <version>2.0.6</version>
    </dependency>
</dependencies>

2.编写配置文件

  • 实体类 user
  • 接口类 UserMapper
  • 配置 UserMapper.xml

3.测试mybatis

1、Spring整合mybatis方式一

创建一个spring的配置文件,在Spring配置文件中整合mybatis的配置

1.编写数据源

<!--DateSource:使用Spring提供的数据源替换Mybatis的配置
使用Spring提供的JDBC:org.springframework.jdbc.datasource
-->
<bean id="dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource">
    <property name="driverClassName" value="com.mysql.jdbc.Driver"/>
    <property name="url" value="jdbc:mysql://localhost:3306/mybatis?useUnicode=true&amp;characterEncoding=UTF-8&amp;serverTimezone=UTC"/>
    <property name="username" value="root"/>
    <property name="password" value="123456"/>
</bean>

2.sqlsessionFactory

<!--sqlSessionFactory
    原来使用的是工具类获取,现在用spring管理-->
<bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
    <property name="dataSource" ref="dataSource" />
    <!--绑定Mybatis配置文件-->
    <property name="configLocation" value="classpath:mybatis-config.xml"/>
    <!--注册mapper,原来是在mybatis的核心配置文件中注册-->
    <property name="mapperLocations" value="classpath:com/yong/mapper/*.xml"/>
</bean>

3.sqlsessionTemplate

SqlSessionTemplate 是 MyBatis-Spring 的核心,作为 SqlSession 的一个实现

<!--SqlSessionTemplate就是我们使用的sqlSession-->
<bean id="sqlSession" class="org.mybatis.spring.SqlSessionTemplate">
    <!--只能使用构造器注入,因为它没有set方法-->
    <constructor-arg index="0" ref="sqlSessionFactory"/>
</bean>

4.需要给接口加实现类

(实现功能的逻辑代码需要放到实现类中)

方式一和方式二的主要区别在这一步。

这里是通过Spring注入私有化一个sqlSession

public class UserMapperImpl implements UserMapper{
    //在原来,我们所有的操作都使用sqlSession来执行,现在都使用SqlSessionTemplate
    private SqlSessionTemplate sqlSession;

    public void setSqlSession(SqlSessionTemplate sqlSession) {
        this.sqlSession = sqlSession;
    }

    public List<User> selectUser() {
        UserMapper mapper = sqlSession.getMapper(UserMapper.class);
        return mapper.selectUser();
    }
}

5.将自己写的实现类注入到spring中

(这样就可以用getBean拿到sqlsession了,不再需要工具类了。)

<bean id="userMapper" class="com.yong.mapper.UserMapperImpl">
    <property name="sqlSession" ref="sqlSession"/>
</bean>

6.测试使用,调用spring

@Test
public void selectUser() throws IOException {
    ClassPathXmlApplicationContext context = new ClassPathXmlApplicationContext("spring-dao.xml");
    UserMapper userMapper = context.getBean("userMapper", UserMapper.class);
    for (User user : userMapper.selectUser()) {
        System.out.println(user);
    }
}

完整配置代码:

<?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: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/aop
       http://www.springframework.org/schema/aop/spring-aop.xsd">
    <!--DateSource:使用Spring提供的数据源替换Mybatis的配置
    使用Spring提供的JDBC:org.springframework.jdbc.datasource
    -->
    <bean id="dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource">
        <property name="driverClassName" value="com.mysql.jdbc.Driver"/>
        <property name="url" value="jdbc:mysql://localhost:3306/mybatis?useUnicode=true&amp;characterEncoding=UTF-8&amp;serverTimezone=UTC"/>
        <property name="username" value="root"/>
        <property name="password" value="123456"/>
    </bean>

    <!--sqlSessionFactory
    原来使用的是工具类获取,现在用spring管理-->
    <bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
        <property name="dataSource" ref="dataSource" />
        <!--绑定Mybatis配置文件-->
        <property name="configLocation" value="classpath:mybatis-config.xml"/>
        <!--注册mapper,原来是在mybatis的核心配置文件中注册-->
        <property name="mapperLocations" value="classpath:com/yong/mapper/*.xml"/>
    </bean>

    <!--SqlSessionTemplate就是我们使用的sqlSession-->
    <bean id="sqlSession" class="org.mybatis.spring.SqlSessionTemplate">
        <!--只能使用构造器注入,因为它没有set方法-->
        <constructor-arg index="0" ref="sqlSessionFactory"/>
    </bean>

    <bean id="userMapper" class="com.yong.mapper.UserMapperImpl">
        <property name="sqlSession" ref="sqlSession"/>
    </bean>
</beans>

2、Spring整合mybatis方式二

继承SqlSessionDaoSupport,这是新方式,是方法一的简化

第四步,同样的给接口一个实现类,继承SqlSessionDaoSupport后直接调用getSqlSession即可

public class UserMapperImpl2 extends SqlSessionDaoSupport implements UserMapper {

    public List<User> selectUser() {
        return getSqlSession().getMapper(UserMapper.class).selectUser();
    }
}

5.将自己写的实现类注入到spring中

(比上面少了一步)

<bean id="userMapper2" class="com.yong.mapper.UserMapperImpl2">
    <property name="sqlSessionFactory" ref="sqlSessionFactory"/>
</bean>

这两种方式起到的作用一样。查看SqlSessionDaoSupport的源码,可以看到,该类也是私有化一个sqlSession,是方法一的简化。

以上是关于Spring整合MyBatis的两种方式的主要内容,如果未能解决你的问题,请参考以下文章

Spring Boot 整合 MyBatis Plus实现多数据源的两种方式

Spring Boot 整合 MyBatis Plus实现多数据源的两种方式

使用mybatis的两种方式

Spring整合Hibernate的两种方式

spring整合struts2的两种方式区别

Spring+SpringMVC+MyBatis+Maven框架整合