如何整合
1.让spring通过单例方式管理SqlSessionFactory。
2.spring和mybatis整合生成代理对象,使用SqlSessionFactory创建SqlSession。(spring和mybatis整合自动完成)
3.持久层的mapper都需要由spring进行管理
整合环境
1.导入mybatis的包
2.导入spring的包
3.导入整合包
将SqlMapConfig中配置的数据源一级SqlSessionFactory交给spring的配置文件来配置
1.spring配置文件如下(我提前配置了dao是为了后面的实验)
2.SqlMapConfig配置文件如下
3.mapper.xml如下
在搭建好的环境下实现整合方式一(用Dao方式开发)
1.编写dao类
2.它的实现类(和hibernate类似,继承了一个DaoSupport类,所以我们注入SqlSessionFactory之后就可以获得Sqlsesion就是源码帮我实现了)
源码如下
3.测试类(先加载spring配置文件,这里我查询两次是为了测试整合之后不关闭SqlSession能不能使用缓存)
4.结果(发现是不用关闭SqlSession的,因为交给spring管理之后,当方法结束时就会自动关闭,如果手动关闭的话就会抛出异常)
方式二:Mapper代理开发
1.编写mapper.xml文件
2.mapper接口
3.去spring文件中配置mapper
4.测试类
5.结果
6.采用第二种方式配置mapper,因为上面那种配置方式如果有很多mapper那么要配置很多次,很麻烦
修改SqlMapConfig文件,不需要再次扫描mapper.xml文件了
7.测试类同上,测试结果如下(效果一样,效率更高了)
好了,spring和mybatis的基础整合就到这里了,实际项目肯定不止这样的,我还需要努力学习!