1. 步骤

第一步:导入相关的jar包(spring和mybatis)

mybatis-spring-*.jar

spring-jdbc-*.jar

spring-tx-*.jar

第二步:spring的配置文件

a)配置数据源

b)配置SqlSession工厂

c)配置SqlSessionTemplate

第三步:mybatis的配置文件

第四步:开发Mapper接口

第五步:Mapper映射文件

第六步:接口实现类

第七步:Service层开发

第八步:注册service和mapper的bean

第九步:测试.

2. bean配置.

<bean id="" class="bean的全限定名"/>

3. 测试的核心类和方法

ApplicationContext act = new ClasspathXMLApplicationContext("spring配置文件");

Bean obj =  act.getBean("id值");

4. MapperFactoryBean注入映射器

<bean id="xx" class="org.mybatis.spring.mapper.MapperFacotyBean">

<property name="mapperInterface" value="mapper接口名称"/>

<property name="sqlSessionFactory" ref="sqlSessionFactory的id"/>

</bean>

5. MapperScannerConfigurer 注入映射器

<bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">

<property name="basePackage" value="com.sm.dao"></property>

</bean>

注意:会读取整个包下的所有的Mapper接口和Mapper映射文件.

在注入Mapper时,的id为接口名的首字母小写.而且它会

自动注入SqlSessonFactoryBean.

6. 配置事务声明

第一步:定义事务管理器

<!-- 配置事务管理器(增强功能) -->

<bean id="txManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">

<property name="dataSource" ref="dataSource"></property>

</bean>

第二步: 建议者

<!-- 配置不同方法的事物处理功能(建议者)

<tx:advice id="txAdvice" transaction-manager="txManager">

<tx:attributes>-->

<!-- 配置目标方法名 -->

<tx:method name="insert*" propagation="REQUIRED" isolation="DEFAULT" timeout="-1" no-rollback-for="" rollback-for="RuntimeException"/>

<tx:method name="delete*"/>

<tx:method name="update*"/>

<tx:method name="find*" propagation="SUPPORTS"/>

<tx:method name="*"/>

<tx:attributes>

<tx:advice>

第三步: 配置切面

<aop:config>

<aop:pointcut expression="execution(* com.sm.service..*.*(..))" id="txPointcut"/>

<aop:advisor advice-ref="txAdvice" pointcut-ref="txPointcut"/>

</aop:config>

7. 事务属性

propagation:事务传播机制

REQUIRED:如果存在事务,则支持这个事务,如果不存在事务,就开启一个事务

REQUIRES_NEW:总会开启一个新事务

MANDATORY:如果存在事务,则支持这个事务,如果不存在事务,就抛出异常

NESTED:如果存在事务,会开启一个事务去嵌套,如果不存在事务,与REQUIRED一样

SUPPORTS:如果存在事务,则支持这个事务,如果不存在事务,就在非事务的环境下运行

isolation:事务隔离级别

DEFAULT:默认,使用数据库的默认事务隔离级别

READ_UNCOMMITTED:未提及读

READ_COMMITTED:提交读 (脏读)

REPEATABLE_READ:可重复读(不可重复读问题)

SERIALIZABLE:串行读(幻影读)

timeout:多少秒后超时.

readonly:事务只读

rollback-for:触发回滚的异常类型

no-rollback-for:不触发回滚的异常类型

8. 注解事务

第一步:开启事务注解,指定事务管理器

<tx:annotation-driven transaction-manager="txManager"/>

第二步:配置注解事务

@Transaction(属性=属性值,属性1=属性值1..)

MayBatis与Spring的整合的更多相关文章

  1. struts2 spring mybatis 整合(test)

    这几天搭了个spring+struts2+mybatis的架子,练练手,顺便熟悉熟悉struts2. 环境:myEclipse10+tomcat7+jdk1.6(1.8的jre报错,所以换成了1.6) ...

  2. 【Java EE 学习 79 下】【动态SQL】【mybatis和spring的整合】

    一.动态SQL 什么是动态SQL,就是在不同的条件下,sql语句不相同的意思,曾经在“酒店会员管理系统”中写过大量的多条件查询,那是在SSH的环境中,所以只能在代码中进行判断,以下是其中一个多条件查询 ...

  3. 3.springMVC+spring+Mybatis整合Demo(单表的增删该查,这里主要是贴代码,不多解释了)

    前面给大家讲了整合的思路和整合的过程,在这里就不在提了,直接把springMVC+spring+Mybatis整合的实例代码(单表的增删改查)贴给大家: 首先是目录结构: 仔细看看这个目录结构:我不详 ...

  4. 由“单独搭建Mybatis”到“Mybatis与Spring的整合/集成”

    在J2EE领域,Hibernate与Mybatis是大家常用的持久层框架,它们各有特点,在持久层框架中处于领导地位. 本文主要介绍Mybatis(对于较小型的系统,特别是报表较多的系统,个人偏向Myb ...

  5. spring+websocket整合

    java-websocket的搭建非常之容易,没用框架的童鞋可以在这里下载撸主亲自调教好的java-websocket程序: Apach Tomcat 8.0.3+MyEclipse+maven+JD ...

  6. Hibernate 与 Spring 的整合

    刚刚学习了hibernate和Spring的整合,现在来总结一下. 以实现一个功能为例,与大家分享一下整个过程. 需要实现的功能:建立一个Person类,该类包括name,sex,age,birtha ...

  7. Spring与Struts2整合VS Spring与Spring MVC整合

    Spring与Struts2整合,struts.xml在src目录下 1.在web.xml配置监听器 web.xml <!-- 配置Spring的用于初始化ApplicationContext的 ...

  8. struts2+hibernate-jpa+Spring+maven 整合(1)

    1.0.0 struts2 与 spring 的整合. 1.1.0 新建maven工程 , 编写pom.xml ,这里只需要简单的添加 一个组件就够了: 在myeclipse 生成的pom.xml 添 ...

  9. ASP.NET MVC Spring.NET 整合

    请注明转载地址:http://www.cnblogs.com/arhat 在整合这三个技术之前,首先得说明一下整合的步骤,俗话说汗要一口一口吃,事要一件一件做.同理这个三个技术也是.那么在整合之前,需 ...

随机推荐

  1. Windows下如何安装python第三方库lxml

    lxml是个非常有用的python库,它可以灵活高效地解析xml,与BeautifulSoup.requests结合,是编写爬虫的标准姿势. 参考 Windows下如何安装python第三方库lxml ...

  2. RedHat7.4最小化安装没有ifconfig命令

    软件环境 VirtualBox 5.2.8 rhel-server-7.4-x86_64-dvd.iso 系统环境 Win10 64 位 8G内存 最小化安装了RedHat7.4之后,进入系统之后使用 ...

  3. hbase(一)region

    前言 文章不含源码,只是一些官方资料的整理和个人理解 架构总览 这张图在大街小巷里都能看到,感觉是hbase架构中最详细最清晰的一张,稍微再补充几点. 1) Hlog是低版本hbase术语,现在称为W ...

  4. 从0开始 Java学习 packet用法

    packet 包的用法 参考博客:https://www.cnblogs.com/Ring1981/p/6240412.html 用法 java 源文件带有包名,往往容易出错 如:H:\code\He ...

  5. Spring boot 外部资源配置

    tomcat配置访问图片路径映射到磁盘路径   首先,我在调试页面的时候发现,图片路径为: 1 /webapps/pic_son/img/1234565456.jpg 但是,tomcat中webapp ...

  6. ELK 6.x 部署

    Elasticsearch版本:6.3.2 Kibana版本:6.3.2 1.es安装 按照官方提示操作即可. 通过yum安装或者下载tar包解压. 安装完成之后,需要修改一些配置 ①修改文件 /et ...

  7. Canvas绘制不规则图形,实现可拖动,编辑--V1.0第一篇

    目前的工作在做在线的标注工具,接触canvas一年了,各种绘制,基本上图像的交互canvas都可以完成,也写了几篇关于canvas的文章,遇到的问题也写博客上了,对于canvas有问题的朋友可以去看看 ...

  8. PHP中用下划线开头的含义

    命名的规则 加一个为私有的 加两个一般都是系统默认的,系统预定义的,即所谓:=====================“魔术方法”与“魔术常量”=====================★PHP起止为 ...

  9. spark sql 窗口函数over partition by

    1.窗口函数需要使用hiveContext,故引入如下包 libraryDependencies += "org.apache.spark" %% "spark-core ...

  10. MooseFS技术详解

    原文 http://www.tuicool.com/articles/vQvEZ3y MooseFS是一款具有冗余容错功能的分布式文件系统.它把数据分散在多台服务器上,确保一份数据多个备份副本,对外提 ...