Mybatis整合Spring
需求:查询tb_resume中所有人的简历。
分析:不使用Spring,只使用mybatis实现这个功能并不困难,可参考一、Mybatis快速入门 - 池塘里洗澡的鸭子 - 博客园 (cnblogs.com)。
使用Spring,将main主函数中关于没有Mybatis的部分交给Spring管理应该怎么处理呢?哪些内容交给Spring?
如上图为Mybatis代理方式查询数据,整合后我们真正需要执行的业务逻辑只有红框部分,其他部分都应该交给Spring进行管理~即只关心正在的业务逻辑。那么红框外的操作做了哪些工作呢?数据库链接/创建代理对象,综合而言Spring整合Mybatis的目标就明确了,如下:
整合目标:
1)数据库连接池一级事务管理都交给Spring容器完成
2)SqlSessionFactory对象应该放到Spring容器中作为单例对象管理
3)Mapper动态代理对象交给Spring管理,使用时从Spring容器中直接获得Mapper的代理对象
Mybatis提供了一个整合Spring的jar帮助整合:
其他涉及整合坐标如下:
整合过程中配置文件除mapper外,其他全部交给Spring配置文件,配置文件如下:
数据库配置jdbc.properties:
mapper接口:
测试案例:
测试结果: