spring整合mybatis

先上官方文档http://mybatis.org/spring/zh/index.html
大致步骤如下:

1、导入依赖

这次要导入的依赖比较多(学到现在导的最多的一次,后面肯定更多。。)

		<dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-webmvc</artifactId>
            <version>5.3.3</version>
        </dependency>
        <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-jdbc</artifactId>
            <version>5.3.3</version>
        </dependency>
        <dependency>
            <groupId>junit</groupId>
            <artifactId>junit</artifactId>
            <version>4.13.1</version>
            <scope>test</scope>
        </dependency>
        <dependency>
            <groupId>org.aspectj</groupId>
            <artifactId>aspectjweaver</artifactId>
            <version>1.9.6</version>
        </dependency>
        <dependency>
            <groupId>org.mybatis</groupId>
            <artifactId>mybatis-spring</artifactId>
            <version>2.0.6</version>
        </dependency>
        <dependency>
            <groupId>org.mybatis</groupId>
            <artifactId>mybatis</artifactId>
            <version>3.5.6</version>
        </dependency>
        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
            <version>5.1.47</version>
        </dependency>
        

2、配置dataSource

就是设置连接信息(注意看注释里有较详细介绍)

<!--这里使用spring的数据源(Datasource)来替代mybatis的xml核心配置文件
    使用bean来代替配置,class选之前导入的依赖的DriverManagerDataSource
    属性的配置和mybatis的xml核心配置文件中的属性配置相似
    -->
    <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?useSSL=false&amp;serverTimezone=UTC"/>
        <property name="username" value="root"/>
        <property name="password" value="root"/>
    </bean>

3、实现SqlSessionFactory与SqlSessionTemplate

在纯mybatis中都是new出来的,spring需要管理对象,所以这些工作要在spring里面做(注释里有较详细介绍)

<!--SqlSessionFactory的实例也由spring来管理了-->
    <bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
        <property name="dataSource" ref="dataSource" /><!--这里的dataSource要与上边数据源的dataSource对应-->
        <!--在这里面可以配置mybatis核心配置所配置的一切(当然除了dataSource),别名、mapper的注册在这里都可以做-->
        <property name="mapperLocations" value="classpath:com/wt/dao/UserMapper.xml"/><!--完成了mapper.xml的注册-->
        <!--这里也可以绑定mybatis核心配置文件,使得这个mybatis核心配置文件的配置能够在这里发挥作用,当然这里可以完全代替mybatis核心配置文件-->
        <property name="configLocation" value="classpath:mybatis01-config.xml"/>
    </bean>

    <!--SqlSession的实例也由spring来管理了,官方建议叫SqlSessionTemplate-->
    <bean id="sqlSession" class="org.mybatis.spring.SqlSessionTemplate">
        <!--只能使用构造器注入-->
        <constructor-arg index="0" ref="sqlSessionFactory"/>
    </bean>
    <!--从这里向上数的两个bean相当于完成了学mybatis中写的utils的作用,就是产生sqlSession给其他地方用-->

4、写pojo、mapper这些

随便写一些用来测试(当然要看表写)
pojo:

package com.wt.pojo;

public class User {
    private int id;
    private String name;
    private String pwd;

    public User() {
    }

    public User(int id, String name, String pwd) {
        this.id = id;
        this.name = name;
        this.pwd = pwd;
    }

    public int getId() {
        return id;
    }

    public void setId(int id) {
        this.id = id;
    }

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    public String getPwd() {
        return pwd;
    }

    public void setPwd(String pwd) {
        this.pwd = pwd;
    }
}

mapper:

package com.wt.dao;

import com.wt.pojo.User;

import java.util.List;

public interface UserMapper {

    List<User> getAllUsers();
}

mapper.xml:(mybatis的精华)

<?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.wt.dao.UserMapper">
    <select id="getAllUsers" resultType="User">
        select * from mybatis.user;
    </select>
</mapper>

mapperImpl:(相比纯mybtatis要多一个这个,在test的时候调用这个类里面的方法直接拿到结果,注释里有详细介绍)

package com.wt.dao;

import com.wt.pojo.User;
import org.mybatis.spring.SqlSessionTemplate;

import java.util.List;

public class UserMapperImpl implements UserMapper{

    //这里相当于把之前学mybatis时的test内容那个拿到这里了,这里会被注入一个sqlSessionTemplate(也就是sqlSession换一种叫法)
    //然后获取mapper,执行mapper中的方法,再返回结果给调用方
    //多提一嘴,之前学mybatis时的test里面的创建SqlSessionFactory和SqlSession的实例都由spring来完成,这里的sqlSession也是在spring中被注入的
    private SqlSessionTemplate sqlSessionTemplate;

    public void setSqlSessionTemplate(SqlSessionTemplate sqlSessionTemplate) {
        this.sqlSessionTemplate = sqlSessionTemplate;
    }

    public List<User> getAllUsers(){
        UserMapper userMapper = sqlSessionTemplate.getMapper(UserMapper.class);
        return userMapper.getAllUsers();
    }
}

5、把写得mapperImpl在spring中"注册"

<!--这里把写的实现也放到spring里管理,spring管理一切-->
    <bean id="userMapper" class="com.wt.dao.UserMapperImpl">
        <!--注入sqlSession,相当于取了一个sqlSession来用-->
        <property name="sqlSessionTemplate" ref="sqlSession"/>
    </bean>

6、test

@Test
    public void testEv(){

//            try{
//                String resource = "mybatis01-config.xml";
//                InputStream inputStream = Resources.getResourceAsStream(resource);
//                SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);
//                SqlSession sqlSession = sqlSessionFactory.openSession();
//                UserMapper userMapper = sqlSession.getMapper(UserMapper.class);
//                List<User> users = userMapper.getAllUsers();
//                for(User user:users){
//                    System.out.println(user.getName());
//                }
//            } catch(IOException e) {
//                e.printStackTrace();
//            }
        //上面全部被取代了,只需要从spring中拿userMapper对象就行了
        ApplicationContext context = new ClassPathXmlApplicationContext("spring-dao.xml");
        UserMapper userMapper = context.getBean("userMapper",UserMapper.class);
        List<User> users= userMapper.getAllUsers();
        for(User user:users){
            System.out.println(user.getName());
        }

    }

7、更便捷的方法

根据官方文档的介绍,不创建SqlSessionTemplate也可以,直接在用mapperImpl类继承一个类,然后再getSqlSession就ok了,详细:http://mybatis.org/spring/zh/sqlsession.html#SqlSessionDaoSupport
实现:
写mapperImpl类

package com.wt.dao;

import com.wt.pojo.User;
import org.mybatis.spring.SqlSessionTemplate;
import org.mybatis.spring.support.SqlSessionDaoSupport;

import java.util.List;

//这里就更简便了,SqlSessionTemplate的bean都不用创建了,直接继承SqlSessionDaoSupport然后通过getSqlSessionTemplate()方法获得
//sqlSessionTemplate,然后再在这个类的bean中注入SqlSessionFactory的bean就ok了
public class UserMapperImpl2 extends SqlSessionDaoSupport implements UserMapper{
    public List<User> getAllUsers(){
        SqlSessionTemplate sqlSessionTemplate = getSqlSessionTemplate();
        UserMapper userMapper = sqlSessionTemplate.getMapper(UserMapper.class);
        return userMapper.getAllUsers();
    }
}

托管给spring

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

test

@Test
    public void test01(){
        ApplicationContext context = new ClassPathXmlApplicationContext("spring-dao.xml");
        UserMapper userMapper = context.getBean("userMapper2",UserMapper.class);
        List<User> users = userMapper.getAllUsers();
        for(User user:users){
            System.out.println(user.getName());
        }
    }

8、最后再贴一下mybatis核心配置文件

看看和纯mybatis相比有啥不同,当然mybatis核心配置文件可以被spring完全取代

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE configuration
        PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
        "http://mybatis.org/dtd/mybatis-3-config.dtd">
<configuration>

    <typeAliases>
        <package name="com.wt.pojo"></package>
    </typeAliases>

    <!--这里的配置被spring-dao.xml中的bean取代-->
<!--    <environments default="development">-->
<!--        &lt;!&ndash;这个环境用来使用某一用户连接数据库,这里我使用root用户&ndash;&gt;-->
<!--        <environment id="development">-->
<!--            <transactionManager type="JDBC"/>-->
<!--            <dataSource type="POOLED">-->
<!--                <property name="driver" value="com.mysql.jdbc.Driver"/>-->
<!--                <property name="url" value="jdbc:mysql://localhost:3306/mybatis?useSSL=false&amp;serverTimezone=UTC"/>-->
<!--                <property name="username" value="root"/>-->
<!--                <property name="password" value="root"/>-->
<!--            </dataSource>-->
<!--        </environment>-->
<!--    </environments>-->

    <!--写的mapper一定要在这里注册,这里的mapper注册已经被spring代替了-->
<!--    <mappers>-->
<!--        &lt;!&ndash;注意注册的路径不是用.而是用/&ndash;&gt;-->
<!--        <mapper resource="com/wt/dao/UserMapper.xml"/>-->
<!--    </mappers>-->
</configuration>
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值