下面通过一个实例实现 MyBatis 与 Spring 的整合,具体实现过程如下:

1)创建应用并导入相关 JAR 包

创建一个名为 MyBatis-Spring 的 Web 应用,并将《MyBatis与Spring的整合步骤》教程的 JAR 导入 /WEB-INF/lib 目录下。

2)创建持久化类

在 src 目录下创建一个名为 com.po 的包,将《第一个MyBatis程序》教程的持久化类复制到包中。

3)创建 SQL 映射文件和 MyBatis 核心配置文件

在 src 目录下创建一个名为 com.mybatis 的包,在该包中创建 MyBatis 核心配置文件 mybatis-config.xml 和 SQL 映射文件 UserMapper.xml。

UserMapper.xml 的代码如下:

  1. <?xml version=”1.0” encoding=”UTF-8”?>
  2. <!DOCTYPE mapper
  3. PUBLIC “-//mybatis.org//DTD Mapper 3.0//EN”
  4. http://mybatis.org/dtd/mybatis-3-mapper.dtd">
  5. <mapper namespace=”com.dao.UserDao”>
  6. <select id=”selectUserById” parameterType=”Integer” resultType=”com..po.MyUser”>
  7. select * from user where uid = #{uid}
  8. <select id=”selectAllUser” resultType=”com.po.MyUser”>
  9. select * from user
  10. <insert id=”addUser” parameterType=”com.po.MyUser”>
  11. insert into user (uname,usex) values(#{uname},#{usex})
  12. <update id=”updateUser” parameterType=”com..po.MyUser”>
  13. update user set uname = #{uname},usex = #{usex} where uid = #{uid}
  14. <delete id=”deleteUser” parameterType=”Integer”>
  15. delete from user where uid = #{uid}

mybatis-config.xml 的代码如下:

  1. <?xml version=”1.0” encoding=”utf-8”?>
  2. <!DOCTYPE configuration PUBLIC “-//mybatis.org//DTD Config 3.0//EN”
  3. http://mybatis.org/dtd/mybatis-3-config.dtd">
  4. <mapper resource=”com/mybatis/UserMapper.xml” />
  5. 4)创建数据访问接口

    在 src 目录下创建一个名为 com.dao 的包,在该包中创建 UserDao 接口,并将接口使用 @Mapper 注解为 Mapper,接口中的方法与 SQL 映射文件一致。

UserDao 接口的代码如下:

  1. package com.dao;
  2. import java.util.List;
  3. import org.apache.ibatis.annotations.Mapper;
  4. import org.springframework.stereotype.Repository;
  5. import com.po.MyUser;

  6. @Repository(“userDao”)
  7. @Mapper
  8. /*
    • 使用Spring自动扫描MyBatis的接口并装配 (Spring将指定包中所有被@Mapper注解标注的接口自动装配为MyBatis的映射接口
  9. */
  10. public interface UserDao {
  11. /**
    • 接口方法对应的SQL映射文件UserMapper.xml中的id
  12. */
  13. public MyUser selectUserById(Integer uid);

  14. public List selectAllUser();

  15. public int addUser(MyUser user);

  16. public int updateUser(MyUser user);

  17. public int deleteUser(Integer uid);
  18. }

    5)创建日志文件

    在 src 目录下创建日志文件 log4j.properties,文件内容如下:
    # Global logging configuration
    log4j.rootLogger=ERROR,stdout
    # MyBatis logging configuration…
    log4j.logger.com.mybatis=DEBUG
    # Console output…
    log4j.appender.stdout=org.apache.log4j.ConsoleAppender
    log4j.appender.stdout.layout=org.apache.log4j.PatternLayout
    log4j.appender.stdout.layout.ConversionPattern=%5p [%t] - %m%n

    6)创建控制层

    在 src 目录下创建一个名为 com.controller 的包,在包中创建 UserController 类,在该类中调用数据访问接口中的方法。

UserController 类的代码如下:

  1. package com.controller;

  2. import java.util.List;

  3. import org.springframework.beans.factory.annotation.Autowired;
  4. import org.springframework.stereotype.Controller;

  5. import com.dao.UserDao;
  6. import com.po.MyUser;

  7. @Controller(“userController”)
  8. public class UserController {
  9. @Autowired
  10. private UserDao userDao;

  11. public void test() {
  12. // 查询一个用户
  13. MyUser auser = userDao.selectUserById(1);
  14. System.out.println(auser);
  15. System.out.println(“============================”);
  16. // 添加一个用户
  17. MyUser addmu = new MyUser();
  18. addmu.setUname(“陈恒”);
  19. addmu.setUsex(“男”);
  20. int add = userDao.addUser(addmu);
  21. System.out.println(“添加了” + add + “条记录”);
  22. System.out.println(“============================”);
  23. // 修改一个用户
  24. MyUser updatemu = new MyUser();
  25. updatemu.setUid(1);
  26. updatemu.setUname(“张三”);
  27. updatemu.setUsex(“女”);
  28. int up = userDao.updateUser(updatemu);
  29. System.out.println(“修改了” + up + “条记录”);
  30. System.out.println(“============================”);
  31. // 删除一个用户
  32. int dl = userDao.deleteUser(9);
  33. System.out.println(“删除了” + dl + “条记录”);
  34. System.out.println(“============================”);
  35. // 查询所有用户
  36. List list = userDao.selectAllUser();
  37. for (MyUser myUser : list) {
  38. System.out.println(myUser);
  39. }
  40. }
  41. }

    7)创建 Spring 的配置文件

    在 src 目录下创建配置文件 applicationContext.xml,在配置文件中配置数据源、MyBatis 工厂以及 Mapper 代理开发等信息。

applicationContext.xml 的代码如下:

  1. <?xml version=”1.0” encoding=”UTF-8”?>
  2. <beans xmlns=”http://www.springframework.org/schema/beans
  3. xmlns:xsi=”http://www.w3.org/2001/XMLSchema-instance
  4. xmlns:context=”http://www.springframework.org/schema/context
  5. xmlns:tx=”http://www.springframework.org/schema/tx
  6. xmlns:aop=”http://www.springframework.org/schema/aop
  7. xsi:schemaLocation=”http://www.springframework.org/schema/beans
  8. http://www.springframework.org/schema/beans/spring-beans-2.5.xsd
  9. http://www.springframework.org/schema/context
  10. http://www.springframework.org/schema/context/spring-context.xsd
  11. http://www.springframework.org/schema/tx
  12. http://www.springframework.org/schema/tx/spring-tx-2.5.xsd
  13. http://www.springframework.org/schema/aop
  14. http://www.springframework.org/schema/aop/spring-aop-2.5.xsd”>
  15. <context:component-scan base-package=”com.dao” />
  16. <context:component-scan base-package=”com.controller” />
  17. <bean id=”dataSource” class=”org.apache.commons.dbcp.BasicDataSource”>
  18. <property name=”driverClassName” value=”com.mysql.jdbc.Driver” />
  19. <property name=”url”
  20. value=”jdbc:mysql://127.0.0.1:3306/smbms?
  21. useUnicode=true&characterEncoding=utf-8” />
  22. <property name=”username” value=”root” />
  23. <property name=”password” value=”1128” />
  24. <property name=”maxTotal” value=”30” />
  25. <property name=”maxIdle” value=”10” />
  26. <property name=”initialSize” value=”5” />
  27. <bean id=”txManager”
  28. class=”org.springframework.jdbc.datasource.DataSourceTransactionManager”>
  29. <property name=”dataSource” ref=”dataSource” />
  30. <tx:annotation-driven transaction-manager=”txManager” />
  31. <bean id=”sqlSessionFactory” class=”org.mybatis.spring.SqlSessionFactoryBean”>
  32. <property name=”dataSource” ref=”dataSource” />
  33. <property name=”configLocation” value=”classpath:com/mybatis/mybatis-config.xml” />
  34. <bean class=”org.mybatis.spring.mapper.MapperScannerConfigurer”>
  35. <property name=”basePackage” value=”com.dao” />
  36. <property name=”sqlSessionFactoryBeanName” value=”sqlSessionFactory” />
  37. 8)创建测试类

    在 com.controller 包中创建测试类 TestController,代码如下:

  38. package com.controller;


  39. import org.springframework.context.ApplicationContext;
  40. import org.springframework.context.support.ClassPathXmlApplicationContext;

  41. public class TestController {
  42. public static void main(String[] args) {
  43. String xmlPath = “applicationContext.xml”;
  44. ApplicationContext applicationContext = new ClassPathXmlApplicationContext(
  45. xmlPath);
  46. UserController uc = (UserController) applicationContext
  47. .getBean(“userController”);
  48. uc.test();
  49. }
  50. }

上述测试类的运行结果如图 1 所示。

22-MyBatis与Spring的整合实例详解 - 图1
图 1 框架整合测试结果

从第 6 步中的 UserController 类可以看出,开发者只需要进行业务处理,不需要再写 SqlSession 对象的创建、数据库事务的处理等烦琐代码。因此,MyBatis 整合 Spring 后方便了数据库访问操作,提高了开发效率。