前面的内容讨论了mybatis的用法,在实际开发中,最常用的是使用spring与mybatis做整合。因此要用到MyBatis-Spring。MyBatis-Spring 会帮助你将 MyBatis 代码无缝地整合到 Spring 中。它将允许 MyBatis 参与到 Spring 的事务管理之中,创建映射器 mapper 和 SqlSession 并注入到 bean 中,以及将 Mybatis 的异常转换为 Spring 的 DataAccessException。最终,可以做到应用代码不依赖于 MyBatis,Spring 或 MyBatis-Spring。MyBatis-Spring的版本对应情况如下:
引入依赖
spring我们非常熟悉。使用spring首先引入spring常用的五个依赖:
然后是spring管理事务和jdbc的依赖:
我们要使用MySQL数据库,下面引入MySQL和mybatis的几个依赖:
最后是日志依赖:
创建spirng配置
在resource目录下创建spring-mybatis.xml配置文件,
然后就可以在代码中调用了:
spring的基本配置就完成了。启动可以看到加载了配置文件:
在spring中配置mybatis
单独使用mybatis的是,使用过程是首先在公共配置中配置环境,也就是数据源,然后由SqlSessionFactoryBuilder根据数据源创建SqlSessionFactory,再由SqlSessionFactory创建SqlSession。在spring中顺序差不多,不过将由spring的SqlSessionFactoryBean创建SqlSessionFactory,下面看配置,首先配置环境,也就是数据源:
初始化方法init和关闭资源方法close都有定义。
然后根据数据源由spring的SqlSessionFactoryBean创建SqlSessionFactory:
sqlSessionFactory中不仅引用了数据源,还配置了mapper映射文件的路径,这种配置方法配置了resource下面的mappers文件夹下面的所有以xml结尾的文件。自 1.3.0 版本开始,新增的 configuration 属性能够在没有对应的 MyBatis XML 配置文件的情况下,直接设置 Configuration 实例。例如:
下面是配置sqlSession:
最后配置mapper接口类的路径:
上面的配置方法能配置mybatis.mapper包下所有的类。mybatis的配置可以暂时配置到这里。下面简单测试一下查询方法:
查看结果:
通过上面简单的配置,我们完成了初步的spring整合mybatis,实现了一个查询功能。
事务配置
使用 MyBatis-Spring 的其中一个主要原因是它允许 MyBatis 参与到 Spring 的事务管理中。而不是给 MyBatis 创建一个新的专用事务管理器,MyBatis-Spring 借助了 Spring 中的 DataSourceTransactionManager 来实现事务管理。一旦配置好了 Spring 的事务管理器,你就可以在 Spring 中按你平时的方式来配置事务。
事务配置好了以后,MyBatis-Spring 将会透明地管理事务。这样在你的 DAO 类中就不需要额外的代码了。要开启 Spring 的事务处理功能,在 Spring 的配置文件中创建一个 DataSourceTransactionManager 对象:
传入的 DataSource 可以是任何能够与 Spring 兼容的 JDBC DataSource。包括连接池和通过 JNDI 查找获得的 DataSource。
注意:为事务管理器指定的 DataSource 必须和用来创建 SqlSessionFactoryBean 的是同一个数据源,否则事务管理器就无法工作了。
声明式事务
事务用法(增加注解即可):