(十四)mybatis 和 spring 整合
目录
整合思想
让
spring管理sqlSessionFactory,使用单例模式创建该对象 ;根据
sqlSessionFactory创建sqlsession,这一步由mybatis和spring整合 以后,自动完成,不需要我们配置 ;Mapper接口的代理对象 ,由spring管理这些代理对象 ;
整合步骤
导包
导入
spring、mybatis的包导入
mybatis-spring整合包 ;搭建工程目录
需要注意的一点,就是在创建包的时候,为
mybatis、spring都创建各自的配置文件包,便于管理 ;导入
spring、mybatis的配置文件其中注意,
mybatis的配置文件中的environments标签的内容在和spring整合以后,就被废弃了,也就是不再起作用了;也就是
数据源、事务,最后都由spring进行管理了 ;废弃的
environments标签内容 :<!--当和 spring 整合以后,environments 配置将废除-->
<environments default="development">
<environment id="development">
<!--事务管理,暂时有mybatis管-->
<transactionManager type="JDBC"/>
<!--数据源 暂时也由 mybatis 管理,以后都由 spring 来管理-->
<dataSource type="POOLED">
<property name="driver" value="${jdbc.driver}"/>
<property name="url" value="${jdbc.url}"/>
<property name="username" value="${jdbc.username}"/>
<property name="password" value="${jdbc.password}"/>
</dataSource>
</environment>
</environments>在
spring中管理sqlSessionFactorysqlSessionFactory不是我们在mybatis中使用的那个接口,而是在mybatis-springSqlSessionFactoryBean;SqlSessionFactoryBean类部分源码:public class SqlSessionFactoryBean implements FactoryBean<SqlSessionFactory>, InitializingBean, ApplicationListener<ApplicationEvent> {
private static final Log LOGGER = LogFactory.getLog(SqlSessionFactoryBean.class);
// 读取mybatis配置文件使用的资源流
private Resource configLocation;
.....
// 读取数据源
private DataSource dataSource;
.... }
我们可以发现,它的属性有
数据源、资源流,因此,我们在spring中的配置的时候,就需要往相关的属性上赋值了 ;spring中配置sqlSessionFactory:<!--配置 sqlSessionFactory-->
<!--
class :在 mybatis-spring 整合包里面
-->
<bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
<!--设置读取 mybatis 配置文件的资源流-->
<property name="configLocation" value="xin/ijava/config/mybatis/sqlMapConfig.xml"/>
<!--设置数据源,引用下面配置的数据源对象-->
<property name="dataSource" ref="dataSource"/>
</bean> <!--读取数据库的配置文件-->
<content:property-placeholder location="classpath:xin/ijava/config/mybatis/db.properties" /> <!--配置 DBCP 数据源-->
<bean id="dataSource" class="org.apache.commons.dbcp2.BasicDataSource" destroy-method="close">
<property name="driverClassName" value="${jdbc.driver}"/>
<property name="url" value="${jdbc.url}"/>
<property name="username" value="${jdbc.username"/>
<property name="password" value="${jdbc.password"/>
<property name="maxOpenPreparedStatements" value="10"/>
<property name="maxIdle" value="5"/>
</bean>
整合之后原始 dao 开发
开发接口
跟之前
mybatis的原始开发一样,需要写接口 ;配置映射关系文件
和之前单独使用
mybatis开发是一样的 ;开发实现类
跟之前
mybatis的原始开发一样,写接口的实现类 ;让实现类继承
SqlSessionDaoSupport(不同点)继承以后,我们不再需要写上
sqlSessionFactory属性了,因为,在继承类中,有这个属性获取
SqlSession使用this.getSqlSession()并且,不再需要我们自己手动去关闭
sqlSession;/**
* @author An
*/
public class UserDaoImpl extends SqlSessionDaoSupport implements UserDao{ @Override
public void insertUser(User user) throws Exception {
SqlSession sqlSession = this.getSqlSession() ;
sqlSession.insert("test.insertUser",user) ; }
在
spring中配置userDao对象传入
sqlSessionFactory对象 ;<!--配置 UserDao-->
<bean id="userDao" class="xin.ijava.dao.UserDaoImpl">
<property name="sqlSessionFactory" ref="sqlSessionFactory"/>
</bean>
测试代码
public class UserDaoImplTest {
private ApplicationContext context ;
@Before
public void setUp() throws Exception {
context = new ClassPathXmlApplicationContext("xin/ijava/config/spring/application.xml");
}
@Test
public void findUserById() throws Exception {
UserDaoImpl userDao = (UserDaoImpl) context.getBean("userDao");
User user = userDao.findUserById(1) ;
System.out.println(user);
}
}查看控制台输出
[service] 2018-09-12 17:26:22,538 - xin.ijava.dao.UserMapper.findUserById -8617 [main] DEBUG xin.ijava.dao.UserMapper.findUserById - ==> Preparing: select * from User where id = ?
[service] 2018-09-12 17:26:22,720 - xin.ijava.dao.UserMapper.findUserById -8799 [main] DEBUG xin.ijava.dao.UserMapper.findUserById - ==> Parameters: 1(Integer)
[service] 2018-09-12 17:26:22,806 - xin.ijava.dao.UserMapper.findUserById -8885 [main] DEBUG xin.ijava.dao.UserMapper.findUserById - <== Total: 1
[service] 2018-09-12 17:26:22,815 - net.sf.ehcache.store.disk.Segment -8894 [main] DEBUG net.sf.ehcache.store.disk.Segment - put added 0 on heap
[service] 2018-09-12 17:26:22,824 - org.mybatis.spring.SqlSessionUtils -8903 [main] DEBUG org.mybatis.spring.SqlSessionUtils - Closing non transactional SqlSession [org.apache.ibatis.session.defaults.DefaultSqlSession@6dd93e5f]
[service] 2018-09-12 17:26:22,824 - org.springframework.jdbc.datasource.DataSourceUtils -8903 [main] DEBUG org.springframework.jdbc.datasource.DataSourceUtils - Returning JDBC Connection to DataSource
User : name = 张三,id = 1只要看到这个输出,就说明
mybatis和spring整合成功 !!
整合之后 Mapper 代理开发
配置
xxxMapper.xml映射关系文件跟之前
mybatis的原始开发一样;开发接口
跟之前
mybatis的原始开发一样,需要写接口 ;让
spring创建代理对象在
spring的配置文件中,进行配置 ;如果传入的
class是整合包中的MapperFactoryBean类这种方式,需要为每一个接口,都配置一次 ;
<!--配置映射文件代理对象-->
<!--
让 spring 创建代理对象。
-->
<bean id="userMapper" class="org.mybatis.spring.mapper.MapperFactoryBean">
<!--依然需要传入 sqlSessionFactory -->
<property name="sqlSessionFactory" ref="sqlSessionFactory"/>
<!--传入接口,告诉它为我们创建哪一个接口的代理对象-->
<property name="mapperInterface" value="xin.ijava.dao.UserCustomerMapper"/>
</bean>
如果传入的
class是整合包中的MapperScannerConfigurer类这种方式,会批量的扫描接口,我们只需要配置这一次 ;
注意,这里传
sqlSessionFactory进去的时候,使用的是sqlSessionFactoryBeanName;<!--扫描包下的所有接口,一次性生成诸多代理对象,并在 spring 中注册-->
<!--自动创建的代理对象的 id 为 类名字(首字母小写,必须小写)-->
<bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
<!--配置包名 -->
<!--要是扫描多个包,中间用逗号隔开-->
<property name="basePackage" value="xin.ijava.dao"/>
<!--依然传入 sqlSessionFactory-->
<!--value 的值是之前配置的 SqlSessionFactory 的 id-->
<!--这里 name 不能写 sqlSessionFactory ,因为这里先执行;
假如写为sqlSessionFactory属性,那么上面配置的加载数据库配置文件的配置,将不会得到执行 -->
<property name="sqlSessionFactoryBeanName" value="sqlSessionFactory"/>
</bean>如果使用了批量注册注册
mapper,那么mybatis的配置文件中就 不再需要进行mapper.xml的扫描;对了,这里有个坑,除了使用
sqlSessionFactoryBeanName代替sqlSessionFactory;还需要去掉开头的default-autowire="byName";使用批量加载的方法的测试代码
public class UserCustomerMapperTest {
private ApplicationContext context ;
@Before
public void setUp() throws Exception {
context = new ClassPathXmlApplicationContext("xin/ijava/config/spring/application.xml");
} @Test
public void findOrderUsers() throws Exception { UserCustomerMapper userCustomerMapper = (UserCustomerMapper) context.getBean("userCustomerMapper");
List<UserCustomer> userCustomers = userCustomerMapper.findOrderUsers();
System.out.println(userCustomers);
}
}测试结果
[service] 2018-09-12 20:25:02,662 - org.mybatis.spring.transaction.SpringManagedTransaction -8640 [main] DEBUG org.mybatis.spring.transaction.SpringManagedTransaction - JDBC Connection [1728792864, URL=jdbc:mysql:///mybatisDay01?charset=utf-8, UserName=root@localhost, MySQL Connector Java] will not be managed by Spring
[service] 2018-09-12 20:25:02,684 - xin.ijava.dao.UserCustomerMapper.findOrderUsers -8662 [main] DEBUG xin.ijava.dao.UserCustomerMapper.findOrderUsers - ==> Preparing: SELECT `order`.* ,`user`.`name` ,`user`.sex FROM `order`,`user` WHERE `user`.id = `order`.user_id
[service] 2018-09-12 20:25:02,818 - xin.ijava.dao.UserCustomerMapper.findOrderUsers -8796 [main] DEBUG xin.ijava.dao.UserCustomerMapper.findOrderUsers - ==> Parameters:
[service] 2018-09-12 20:25:02,927 - xin.ijava.dao.UserCustomerMapper.findOrderUsers -8905 [main] DEBUG xin.ijava.dao.UserCustomerMapper.findOrderUsers - <== Total: 4
[service] 2018-09-12 20:25:02,937 - org.mybatis.spring.SqlSessionUtils -8915 [main] DEBUG org.mybatis.spring.SqlSessionUtils - Closing non transactional SqlSession [org.apache.ibatis.session.defaults.DefaultSqlSession@1c3bf543]
[service] 2018-09-12 20:25:02,937 - org.springframework.jdbc.datasource.DataSourceUtils -8915 [main] DEBUG org.springframework.jdbc.datasource.DataSourceUtils - Returning JDBC Connection to DataSource
[User : name = 朱小明,id = 0, User : name = 张三,id = 0, User : name = 张小明,id = 0, User : name = 张三,id = 0]只要控制台出现了我们打印的对象,就说明
mybatis 和 spring 整合成功 !!
总结
我们发现,其实无论是 原始开发,还是 mapper 代理,接口 和 映射关系文件,都少不了!
(十四)mybatis 和 spring 整合的更多相关文章
- MyBatis学习(四)MyBatis和Spring整合
MyBatis和Spring整合 思路 1.让spring管理SqlSessionFactory 2.让spring管理mapper对象和dao. 使用spring和mybatis整合开发mapper ...
- Mybatis与Spring整合,使用了maven管理项目,作为初学者觉得不错,转载下来
转载自:http://www.cnblogs.com/xdp-gacl/p/4271627.html 一.搭建开发环境 1.1.使用Maven创建Web项目 执行如下命令: mvn archetype ...
- Mybatis+struts2+spring整合
把student项目改造成ssm struts2 +mybatis+spring 1,先添加spring支持:类库三个,applicationContext.xml写在webinf下四个命名空间,监 ...
- MyBatis 与 Spring 整合
MyBatis-Spring 项目 目前大部分的 Java 互联网项目,都是用 Spring MVC + Spring + MyBatis 搭建平台的. 使用 Spring IoC 可以有效的管理各类 ...
- Mybatis(六) Spring整合mybatis
心莫浮躁~踏踏实实走,一步一个脚印,就算不学习,玩,能干嘛呢?人生就是那样,要找点有意思,打发时间的事情来做,而钻研技术,动脑动手的过程,还是比其他工作更有意思些~ so,努力啥的都是强迫自己做自以为 ...
- 【MyBatis学习14】MyBatis和Spring整合
前面十几篇博文总结了mybatis在开发中的相关技术,但在实际中都是和spring整合开发的,所以这里总结一下mybatis和spring的整合方法,并在整合后进行测试. 1. 整合的环境 这都是老掉 ...
- mybatis与spring整合(基于配置文件)
本文主要介绍了如何将mybatis和spring整合在一起使用,本人使用的是mybatis3.05 + spring3.1.0M2 ,使用dbcp作为数据库连接池. 1.编写数据访问接口(UserDa ...
- mybatis与spring整合时读取properties问题的解决
在学习mybatis与spring整合是,想从外部引用一个db.properties数据库配置文件,在配置文件中使用占位符进行引用,如下: <context:property-placehold ...
- Spring+SpringMVC+MyBatis深入学习及搭建(九)——MyBatis和Spring整合
转载请注明出处:http://www.cnblogs.com/Joanna-Yan/p/6964162.html 前面讲到:Spring+SpringMVC+MyBatis深入学习及搭建(八)--My ...
随机推荐
- openssl 模块 安装 centso Ubuntu
备忘: centos: yum install openssl-devel ubuntu: apt-get install libssl-dev 哎... 这玩意总是记不住. 每次都得搜索好麻烦.
- JVM备忘点(1.8以前)
1.内存结构 左边两个线程共享,右边三个线程私有. 方法区:.class文件的类信息.常量.static变量.即时编译器编译后的代码(动态代理).HotSpot将方法区称为永久代 堆:分为新生代和老年 ...
- Python学习日记(四)——Python基本数据类型梳理(int、str、list、tuple、dict)
数字(int) 1.创建方式 n1 = 123 n2 = int(123) 2.内存分配 #共同用一个内存地址的情况 n1 = 123 n2 = n1 #用两个内存地址的情况 n1 = 123 n2 ...
- ORM SQLAlchemy 简介
对象关系映射(Object Relational Mapping,简称ORM使用DB-API访问数据库,需要懂 SQL 语言,能够写 SQL 语句,如果不想懂 SQL,又想使用关系型数据库,可以使用 ...
- Java操作Cookie方法
特别提示:本人博客部分有参考网络其他博客,但均是本人亲手编写过并验证通过.如发现博客有错误,请及时提出以免误导其他人,谢谢!欢迎转载,但记得标明文章出处:http://www.cnblogs.com/ ...
- ubuntu上面Parity 安装
sudo wget https://raw.githubusercontent.com/paritytech/parity/master/scripts/parity.service -O /et ...
- What do you do as a DevOps?
https://ilhicas.com/2019/08/11/What-you-as-a-Devops.html Introduction In this post I'll just explain ...
- Wamp win10 1077error
检查日志发现了1077错误 State of services: The service 'wampapache64' is NOT started EXIT error code:1077 He ...
- TPCH测试工具
TPC现有的测试标准为:TPC-E.TPC-C.TPC-H.TPC-App.根据这4个测试基准,目前TPC主要包括的4个技术小组委员会:TPC-E 技术小组委员会.TPC-C 技术小组委员会.TPC- ...
- Java HttpClient Post请求参数格式为XML
1.最近忙着做一个接口,拿到文档的时候,what?我当时就震惊了,全都是XML数据传输. 我当时就懵了,哎没得办法,在暑假传输这方面笔者比较熟练json格式数据,简单易懂啊 那就学呗. 2.我在使用的 ...