不需要怎么修改配置的Mybatis整合Spring要点
首先对于Mybatis的主配置文件,只需要修改一处地方,将事务交给Spring管理,其它地方可以原封不动。
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE configuration
PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-config.dtd"> <configuration>
<properties resource="jdbc.properties"></properties> <typeAliases>
<package name="com.sunwii.mybatis.bean" />
</typeAliases> <environments default="development">
<environment id="development">
<!--将事务交张Spring管理-->
<transactionManager type="org.mybatis.spring.transaction.SpringManagedTransactionFactory" />
<dataSource type="POOLED">
<property name="driver" value="${driver}" />
<property name="url" value="${url}" />
<property name="username" value="${user}" />
<property name="password" value="${password}" />
</dataSource>
</environment>
</environments>
<!--这里mappers块可以保留或删除或配置不存在的包也无所谓-->
<mappers>
<package name="Xcom/sunwii/mybatis/mapper"></package>
</mappers>
</configuration>
然后修改一下Mybatis工具类,重新命令为SqlSessionFactoryBuilder:
public class SessionFactoryBuilder {
private String mybatisConfigPath;
public String getMybatisConfigPath() {
return mybatisConfigPath;
}
public void setMybatisConfigPath(String mybatisConfigPath) {
this.mybatisConfigPath = mybatisConfigPath;
}
public SqlSessionFactory createSqlSessionFactory() {
SqlSessionFactory factory = null;
InputStream inputStream;
try {
inputStream = Resources.getResourceAsStream(this.mybatisConfigPath);
factory = new SqlSessionFactoryBuilder().build(inputStream);
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
return factory;
}
}
Spring的配置文件也就比较简洁:
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:context="http://www.springframework.org/schema/context"
xmlns:p="http://www.springframework.org/schema/p"
xmlns:aop="http://www.springframework.org/schema/aop"
xmlns:tx="http://www.springframework.org/schema/tx"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-4.0.xsd
http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-4.0.xsd
http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-4.0.xsd http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-4.0.xsd
http://www.springframework.org/schema/util http://www.springframework.org/schema/util/spring-util-4.0.xsd"> <!-- 动态工厂实例化一个SqlSessionFactory -->
<bean id="sessionFactoryBuilder" class="com.sunwii.mybatis.util.SessionFactoryBuilder">
<property name="mybatisConfigPath" value="mybatis-config.xml" />
</bean>
<bean id="sessionFactory" factory-bean="sessionFactoryBuilder" factory-method="createSqlSessionFactory" /> <!-- Mapper动态代理开发扫描 -->
<bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
<property name="basePackage" value="com.sunwii.mybatis.mapper" />
</bean> <!-- 事务管理器 -->
<bean id="transactionManager"
class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
<property name="dataSource"
value="#{sessionFactory.configuration.environment.dataSource}" />
</bean> <!-- 注解事务 -->
<tx:annotation-driven
transaction-manager="transactionManager" /> <!-- Service扫描 -->
<context:component-scan
base-package="com.sunwii.mybatis.service.impl" /> </beans>
关键点就在于:将 org.apache.ibatis.session.SqlSessionFactory 用Spring容器创建出来
有3种方式:
1. mybatis.spring整合包的方式:正常来说可以直接配置 org.mybatis.spring.SqlSessionFactoryBean 来创建,但本例为了减少配置量,减少Mybatis的变动,以及简洁起见,使用了自定义方式。
2. 自定义动态工厂方式:使用了自定义的动态工厂SessionFactoryBuilder(从单独使用的Mybatis工具类中修改而来)方法来创建SqlSessionFactory。
这样的话,原先在Mybatis主配置里配置的JDBC,数据源之类的,不需移动到Spring中,而事务管理器中只需要引Spring表达式引用即可: #{sessionFactory.configuration.environment.dataSource}。
3. 自定义FactoryBean<SqlSessionFactory>接口方式:这就跟mybatis-spring.jar包整合的创建方式相类似(主要代码跟自定义动态工厂方法差不多,但需要实现好几个FactoryBean的方法,代码稍多,为简洁起见,不使用)
最后就是Service中直接使用Mapper接口了:
@Service
public class RoleServiceImpl implements RoleService {
@Autowired
private RoleMapper roleMapper;
@Autowired
private RolePermissionMapper rolePermissionMapper;
@Autowired
private PermissionMapper permissionMapper; @Override
@Transactional
public int insertRole(Role role) { int rs = 0; rs = roleMapper.insert(role); //Permission permission = permissionMapper.selectById(56);
//role.setPermissions(Arrays.asList(permission)); Permission permission = new Permission();
permission.setName("permission-" + 1);
permissionMapper.insert(permission); // 0 / 0 测试事务回滚
new Integer(0 / 1); RolePermission rolePermission = new RolePermission();
rolePermission.setRole(role);
rolePermission.setPermission(permission);
rolePermissionMapper.insert(rolePermission); return rs;
} @Override
public Role getRoleById(Integer id) {
return roleMapper.selectById(id);
} }
说明:
由于采用了Mapper接口的方式来进行开发,org.mybatis.spring.mapper.MapperScannerConfigurer 在处理接口的时候,
经处理后的Mapper接口层用到了SqlSessionDaoSupport及SqlSessionTemplate,所以不需要担心SqlSession线程安全问题,并且也不需要直接使用SqlSession,直接使用的是Mapper接口。
如果不采用Mapper接口开发,为了SqlSession线程安全问题,可以有几种处理方式:
1。可以自定义ThreadLocal<SqlSession>,代码较多,事务管理麻烦,不推荐。上边所有配置不变
2。让daoImpl 实现SqlSessionDaoSupport并注入SqlSessionFactory就可以了。上边所有配置不变
3。让daoImpl 中注入SqlSessionTemplate就可以了。上边所有配置不变,但多加一个SqlSessionTemplate的配置。
----------END OF 不需要怎么修改配置的Mybatis整合Spring要点------------------
不需要怎么修改配置的Mybatis整合Spring要点的更多相关文章
- JAVAEE——Mybatis第二天:输入和输出映射、动态sql、关联查询、Mybatis整合spring、Mybatis逆向工程
1. 学习计划 1.输入映射和输出映射 a) 输入参数映射 b) 返回值映射 2.动态sql a) If标签 b) Where标签 c) Sql片段 d) Foreach标签 3.关联查询 a) 一对 ...
- (转)MyBatis框架的学习(六)——MyBatis整合Spring
http://blog.csdn.net/yerenyuan_pku/article/details/71904315 本文将手把手教你如何使用MyBatis整合Spring,这儿,我本人使用的MyB ...
- mybatis整合spring 之 基于接口映射的多对一关系
转载自:http://my.oschina.net/huangcongmin12/blog/83731 mybatis整合spring 之 基于接口映射的多对一关系. 项目用到俩个表,即studen ...
- mybatis整合spring获取配置文件信息出错
描述:mybatis整合spring加载jdbc.properties文件,然后使用里面配置的值来 配置数据源,后来发现用户变成了admin- jdbc.properties的配置: 加载配置: 报错 ...
- Mybatis整合Spring -- typeAliasesPackage
Mybatis整合Spring 根据官方的说法,在ibatis3,也就是Mybatis3问世之前,Spring3的开发工作就已经完成了,所以Spring3中还是没有对Mybatis3的支持. 因此由M ...
- 160330、Mybatis整合Spring
转自csdn文章 http://haohaoxuexi.iteye.com/blog/1843309 Mybatis整合Spring 根据官方的说法,在ibatis3,也就是Mybatis3问世之前, ...
- Mybatis整合spring(适合小白)
目录 1.整合思路 2.整合需要的jar包 3.整合的步骤 4.Dao的开发的两种实现方式 6.Dao的开发的实现方式总结图 @ Mybatis整合spring其实就是SSM框架中SM的整合集成. 1 ...
- Mybatis整合spring详细教程(适合小白童鞋)
目录 1.整合思路 2.整合需要的jar包 3.整合的步骤 4.Dao的开发的两种实现方式 6.Dao的开发的实现方式总结图 @ Mybatis整合spring其实就是SSM框架中SM的整合集成. 1 ...
- JavaWeb_(Mybatis框架)MyBatis整合Spring框架
MyBatis + Spring整合开发 a)使用Spring容器用单例模式管理Mybatis的sqlSessionFactory:b)使用Spring管理连接池.数据源等:c)将Dao/Mapper ...
随机推荐
- Mybatis-Plus学习.,简化你的开发,提升开发效率.
Mybatis-Plus学习以及实践 简介 参考网址 开发环境 开始开发 - 配置pom.xml - Dao/Service/Entity - 基本方法 - 查询类 - 更新类 分页插件 - pom. ...
- FastEarth
1 概述 FastEarth(后文简称FE)是自主研发的跨平台三维地理信息可视化协作平台,内置完全自主研发的XDR渲染引擎,无缝对接主流地理信息平台数据.建筑BIM.工厂PIM以及多种三 ...
- Scala 学习笔记之集合(4)
集合的模式匹配操作: object CollectionDemo5 { def main(args: Array[String]): Unit = { //集合模式匹配1 val ls = List( ...
- mac 安装redis及phpredis扩展
下载phpredis扩展安装包.git clone https://github.com/nicolasff/phpredis.git: 解压后,进入该目录: 依次执行以下操作完成安装: /Appli ...
- Curl的移植编译以及注意事项
最近需要用curl来发送http请求,遇到了不少问题,查了不少资料,都是零零散散的,现在总结下. 1.移植编译 ./configure --prefix=$(PWD)/build --host=a ...
- java第1天:简介,入门程序,变量,常量
1 java语言简介 美国的SUN公司开发的静态面向对象的编程语言,后来被甲骨文公司收购,现在也是全球范围内最受欢迎的编程语言. *** 2 计算机进制的相互转换 进制 英文代号 2进制 bin 8进 ...
- 前端css杂记
1em等于16px,页面默认是16px,一个字宽高都等于16px; 当行内元素display:inline的元素设置float:left浮动后,display值也被设置成block;总结:无论行内元素 ...
- 【USACO 5.3.1】量取牛奶
农夫约翰要量取 Q(1 <= Q <= 20,000)夸脱(夸脱,quarts,容积单位——译者注) 他的最好的牛奶,并把它装入一个大瓶子中卖出.消费者要多少,他就给多少,从不有任何误差. ...
- 【EasyCi】持续集成交付,一键式自动化部署系统,开箱即用
前言 本人是一家互联网公司的java开发,由于公司初期公司未招运维人员,恰好我对linux比较熟悉,便在公司服务器搭建了一套Jenkins.Gitlab.Maven私服.Docker私服.Sonarq ...
- unittest生成测试报告
1.先导入HTMLTestRunner模块 2.实例一脚本如下 #coding=utf-8 import unittest import HTMLTestRunner #封装批量执行用例 def al ...