博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
【MyBatis学习14】MyBatis和Spring整合
阅读量:6516 次
发布时间:2019-06-24

本文共 4521 字,大约阅读时间需要 15 分钟。

 前面十几篇博文总结了mybatis在开发中的相关技术,但在实际中都是和整合开发的,所以这里总结一下mybatis和spring的整合方法,并在整合后进行测试。

1. 整合的环境

  这都是老掉牙的问题了,不管是开发还是整合,首先环境肯定得有,环境嘛,除了环境和开发环境外,那就是jar包咯,关于mybatis和spring整合的jar包,我已经上传到下载频道了==>  http://download.csdn.net/detail/eson_15/9549624

  将这些jar包导入到lib文件夹中即可,然后就是工程中的一些文件了,配置文件啊,java文件啊等,先看一下整个工程的结构。

 

工程结构 

  下面来完成所有的整合步骤。

 

2. 配置文件

 

  在于spring整合之前,mybatis都是自己管理数据源的,然后sqlSessionFactory是我们自己去注入的,现在整合了,这些都要交给spring来管理了,来看一下beans.xml文件中的配置:

 

 

跟spring和整合的情况差不多,都是通过properties文件加载连接信息,然后导入配置文件配置一下sessionFactory,下面看看db.properties和SqlMapConfig.xml文件。

#db.propertiesdataSource=org.apache.commons.dbcp.BasicDataSourcejdbc.driver=com.mysql.jdbc.Driverjdbc.url=jdbc\:mysql\://localhost\:3306/mybatisjdbc.username=rootjdbc.password=root

3. dao方式开发的配置

  在最开始我们提到,mybatis中有两种开发方式,一种dao开发方式,一种mapper开发方式,后者用的比较多,但是不排除没有使用dao方式的,所以两种我都总结一下,首先看dao方式开发的配置。

3.1 配置User.xml

  在sqlMap包中有个User.xml,里面是针对用户的操作的一些配置,这里是整合,所以我就写了一个statement,如下:

 

 

 只是通过id查询用户,如果测试成功,说明整合成功,这里写完了后,别忘了在SqlMapConfig.xml中加载这个映射文件,但是上面已经加载过了,即<mapper resource="sqlmap/User.xml" />

3.2 开发dao及其实现类

  接下来就是开发dao及其实现类了,就一个方法,通过id查询用户,先来看下dao的方法:

 

public interface UserDao {    //根据用户id查询用户信息    public User findUserById(int id) throws Exception;}

 

再看下实现类:

 

public class UserDaoImpl extends SqlSessionDaoSupport implements UserDao {    @Override    public User findUserById(int id) throws Exception {        //继承SqlSessionDaoSupport,通过this.getSqlSession()就能得到sqlSession,因为SqlSessionDaoSupport中有该方法        SqlSession sqlSession = this.getSqlSession();        User user = sqlSession.selectOne("test.findUserById", id);        return user;    }}

 

 这里是重点:通过dao方式开发的话,dao的实现类在实现接口的同时,需要继承SqlSessionDaoSupport类,这个类中有获取SqlSession的方法,因为sqlSessionFactory已经在beans.xml文件中配置好了(下面有写),spring会自动注入进去,继承了SqlSessionDaoSupport类就可以直接通过getSqlSession()方法来获取sqlSession。然后就可以操作数据库了。

3.3 配置dao

  上面也说了,要获取sqlSession必须得有sqlSessionFactory才行啊,这就需要spring来注入了,所以我们在beans.xml中配置一下该dao

 

 

这样的话,dao开发方式就整合好了,下面来测试一下:

public class UserDaoImplTest {    private ApplicationContext applicationContext;    @Before    public void setUp() throws Exception {        applicationContext = new ClassPathXmlApplicationContext("classpath:beans.xml");//得到spring容器    }    @Test    public void testFindUserById() throws Exception {        UserDao userDao = (UserDao) applicationContext.getBean("userDao");//获取这个bean        User user = userDao.findUserById(1);        System.out.println(user);    }}

4. mapper方式开发的配置

  由前面的博文可知,mapper方法开发的话,mapper.xml和mapper.java文件要放在一个包下,这里主要放在ssm.mapper的包下了,下面看一下两个文件:

4.1 配置UserMapper.xml和UserMapper.java

//mapper接口,相当于dao接口public interface UserMapper {    //根据id查询用户信息    public User findUserById(int id) throws Exception;}

 这个和之前的都一样,没什么难度,注意xml中的namespace要写成对应的java文件的完全限定名即可。

4.2 配置beans.xml

  上面已经配置好了mapper的映射和接口了,那么如何由spring来产生一个代理对象呢?spring是通过MapperFactoryBean来创建代理对象的,看下面的配置:

 

 

从配置中可以看出,使用MapperFactoryBean来产生mapper的代理对象,首先要配置一个mapperInterface,即你要spring产生哪个mapper接口对应的代理对象,所以肯定要把我们刚刚写好的mapper接口的完全限定名给传进去,spring就知道要创建对应的代理对象了。当然,sqlSessionFactory是必不可少的,否则怎么产生sqlSession呢? 

  测试程序把上面的测试程序改一下,获取”userMapper”这个bean即可。 如下

   

@Test   //mapper方式    public void testFindUserById1() throws Exception {            UserMapper userMapper = (UserMapper) applicationContext.getBean("userMapper");//获取这个bean        User user=userMapper.findUserById(1);        System.out.println(user);    }

 

 

但是问题来了,如果有很多个mapper接口咋整?那beans.xml中难道要写很多个这样的bean么?答案肯定不是这样,我们可以在beans.xml中通过扫描包即可,即告诉spring,你把指定的包中所有的mapper接口都给我生成一个代理对象出来,如下:

 

 

从上面的配置中可以看出,spring使用MapperScannerConfiger来进行mapper扫描的。要想扫描成功,必须遵循之前说的规范:即mapper.xml和mapper.java两个文件名必须保持一致,且在同一个目录下。这样的话,自动扫描出来的mapper的bean的id就为mapper类名的首字母小写。所以上面的bean没有id属性,因为这个是根据具体的mapper接口来的。basePackage是用来指定要扫描的包。这样就可以批量扫描mapper接口了。 

  测试程序和上面的一样,就不写了。 
  到这里,spring和mybatis就整合好了,这里只是简单整合一下,主要是了解这个整合的过程以及方法,并没有用到spring的aop和事务等配置,等后面写具体的项目的时候,我再写吧,先就写这么多~ 

你可能感兴趣的文章
使用eclipse与android studio 在开发自定义控件时的区别
查看>>
我的友情链接
查看>>
mysql学习笔记
查看>>
年年有鱼游戏Android源码项目
查看>>
java使用Iterator、for循环同步数据
查看>>
创建镜像iso文件
查看>>
Linux下创建软RAID5和RAID10实战
查看>>
C++类的存储
查看>>
ActiveReports 报表应用教程 (8)---交互式报表之动态过滤
查看>>
解决使用Handler时Can't create handler inside thread that has not called Looper.prepare()
查看>>
跟我一起学docker(四)--容器的基本操作
查看>>
磁化强度
查看>>
C/C++ 数据范围
查看>>
LVS+keepalived+nginx
查看>>
monkey如何通过uiautomatorviewer的bounds坐标点击控件
查看>>
第22章,mysql数据库-1
查看>>
【亲测】教你如何搭建 MongoDB 复制集 + 选举原理
查看>>
虚拟化网络技术
查看>>
阿里云中间件推出全新开发者服务
查看>>
56.随机产生的id重复问题
查看>>