首先对于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接口层用到了SqlSessionDaoSupportSqlSessionTemplate,所以不需要担心SqlSession线程安全问题,并且也不需要直接使用SqlSession,直接使用的是Mapper接口。

如果不采用Mapper接口开发,为了SqlSession线程安全问题,可以有几种处理方式:

1。可以自定义ThreadLocal<SqlSession>,代码较多,事务管理麻烦,不推荐。上边所有配置不变

2。让daoImpl 实现SqlSessionDaoSupport并注入SqlSessionFactory就可以了。上边所有配置不变

3。让daoImpl 中注入SqlSessionTemplate就可以了。上边所有配置不变,但多加一个SqlSessionTemplate的配置。

----------END OF 不需要怎么修改配置的Mybatis整合Spring要点------------------

不需要怎么修改配置的Mybatis整合Spring要点的更多相关文章

  1. JAVAEE——Mybatis第二天:输入和输出映射、动态sql、关联查询、Mybatis整合spring、Mybatis逆向工程

    1. 学习计划 1.输入映射和输出映射 a) 输入参数映射 b) 返回值映射 2.动态sql a) If标签 b) Where标签 c) Sql片段 d) Foreach标签 3.关联查询 a) 一对 ...

  2. (转)MyBatis框架的学习(六)——MyBatis整合Spring

    http://blog.csdn.net/yerenyuan_pku/article/details/71904315 本文将手把手教你如何使用MyBatis整合Spring,这儿,我本人使用的MyB ...

  3. mybatis整合spring 之 基于接口映射的多对一关系

    转载自:http://my.oschina.net/huangcongmin12/blog/83731 mybatis整合spring 之  基于接口映射的多对一关系. 项目用到俩个表,即studen ...

  4. mybatis整合spring获取配置文件信息出错

    描述:mybatis整合spring加载jdbc.properties文件,然后使用里面配置的值来 配置数据源,后来发现用户变成了admin- jdbc.properties的配置: 加载配置: 报错 ...

  5. Mybatis整合Spring -- typeAliasesPackage

    Mybatis整合Spring 根据官方的说法,在ibatis3,也就是Mybatis3问世之前,Spring3的开发工作就已经完成了,所以Spring3中还是没有对Mybatis3的支持. 因此由M ...

  6. 160330、Mybatis整合Spring

    转自csdn文章 http://haohaoxuexi.iteye.com/blog/1843309 Mybatis整合Spring 根据官方的说法,在ibatis3,也就是Mybatis3问世之前, ...

  7. Mybatis整合spring(适合小白)

    目录 1.整合思路 2.整合需要的jar包 3.整合的步骤 4.Dao的开发的两种实现方式 6.Dao的开发的实现方式总结图 @ Mybatis整合spring其实就是SSM框架中SM的整合集成. 1 ...

  8. Mybatis整合spring详细教程(适合小白童鞋)

    目录 1.整合思路 2.整合需要的jar包 3.整合的步骤 4.Dao的开发的两种实现方式 6.Dao的开发的实现方式总结图 @ Mybatis整合spring其实就是SSM框架中SM的整合集成. 1 ...

  9. JavaWeb_(Mybatis框架)MyBatis整合Spring框架

    MyBatis + Spring整合开发 a)使用Spring容器用单例模式管理Mybatis的sqlSessionFactory:b)使用Spring管理连接池.数据源等:c)将Dao/Mapper ...

随机推荐

  1. 如何评价一个VR体验设计?

    如何评价一个VR系统的体验是好是坏?或者说,哪些因素会破坏一个VR的体验? Kruij和Riecke教授在IEEE VR会议上提到了四个角度:Congnition,Game User Experien ...

  2. TP5安装workerman版本的坑

    今天想在TP5上安装workerman,用于个人学习,然后悲剧的是,第一步就卡住了,根据手册里说的首先通过composer安装 composer require topthink/think-work ...

  3. phaser学习总结之Tween详解

    前言 在上一章phaser学习总结之phaser入门教程中,我们已经初步入门了phaser,并通过一个案例了解了phaser,现在我们需要对phaser中的对象进行讲解,本章需要讲解的是tween,即 ...

  4. pycharm 2019/10 激活码 最新福利 (1)

    MTW881U3Z5-eyJsaWNlbnNlSWQiOiJNVFc4ODFVM1o1IiwibGljZW5zZWVOYW1lIjoiTnNzIEltIiwiYXNzaWduZWVOYW1lIjoiI ...

  5. 版本控制之Git小结

    一.版本控制 1.1 什么是版本控制 版本控制是一种记录一个或若干个文件内容变化,以便将来查阅特定版本修订情况的系统.可以对任何类型的文件进行版本控制. 1.2 为什么需要版本控制 有了版本控制就可以 ...

  6. 为什么一个Http Header中的空格会被骇客利用 - HTTP request smuggling

    figure:last-child { margin-bottom: 0.5rem; } #write ol, #write ul { position: relative; } img { max- ...

  7. 深入理解Netty框架

    前言 本文讨论的主题是Netty框架,本着3W原则 (What 是什么?->Why 为什么?->How 如何做?)来一步步探究Netty原理和本质以及运用场景. 了解基本名词 1.BIO. ...

  8. Switch-case语句的应用

    /** switch语句有关规则    • switch(表达式)中表达式的值必须是下述几种类型之一:byte,short, char,int,枚举 (jdk 5.0),String (jdk 7.0 ...

  9. Android仿美团地址选择

    最近做了这个功能,分享一下,用的是百度地图api,和美团外卖的地址选择界面差不多,也就是可以搜索或者滑动地图展示地址列表给用户选择,看下效果图先. 文章重点 1.展示地图并定位到“我”的位置2.滑动地 ...

  10. python 安装pyqt

    ---恢复内容开始--- 一.安装 1.官网:www.riverbankcomputing.com 2.使用命令安装,可以自动去官网查找与Python版本号相同的程序进行下载,比较方便,如果不是这样也 ...