Spring与Mybatis整合需要引入一个mybatis-spring.jar包,该整合包有Mybatis提供,可以从Mybatis官网下载。

该jar包提供了几个API:

1.SqlSessionFactoryBean-为整合应用提供SqlSession对象资源。

  在单独使用MyBatis时,所有操作都是围绕SqlSession展开的,SqlSession是通过SqlSessionFactory获取的,SqlSessionFactory又是通过SqlSessionFactoryBuilder创建生成的。

  在Spring和Mybatis整合应用时,同样需要SqlSession,而SqlSessionFactoryBean组件的作用就是通过原SqlSessionFactoryBuilder生成SqlSessionFactory对象,为整合应用提供SqlSession对象。

  SqlSessionFactoryBean在applicationContext.xml中定义格式如下:

  <bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">

    <!-- 指定连接资源 -->

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

    <!-- 指定映射文件 -->

    <property name="mapperLocations" value="classpath:org/tarena/entity/*.xml"/>

  </bean>

  在定义SqlSessionFactoryBean时,可以使用以下常用属性:

  --dataSource:用于指定连接数据库的数据源

  --mapperLocations:用于指定Mapper文件存放的位置

  --configLocation:用于指定Mybatis的配置文件位置,如果指定了该属性,那么会以该配置文件的内容作为配置信息构建对应的SqlSessionFactoryBuilder,但是后续属性                                   指定的内容会覆盖该配置文件里面指定的对应内容。

  --typeAliasesPackage:它一般对应我们的实体类所在的包,这个时候会自动取对应包中不包括包名的简单类名作为包括包名的别名。多个package之间可以用逗号或者分号等                                     来进行分隔。

  --typeAliases:数组类型,用来指定别名的,指定了这个属性后,Mybatis会把这个类型的短名称作为这个类型的别名。

2.MapperFactoryBean-根据指定Mapper接口生成Bean实例。

3.MapperScannerConfigurer-根据指定包批量扫描Mapper接口并生成实例。

  在使用MapperFactoryBean时,有一个Mapper就需要定义一个对应的MapperFactoryBean。但当遇到大量Mapper时就需要使用使用MapperScannerConfigurer组件,通过这个组件会自动扫描各个Mapper接口,并注册对应的MapperFactoryBean对象。

  在定义MapperScannerConfigurer时,只需要指定一个basePackage即可。basePackage用于指定Mapper接口所在的包,这个包及其所有子包下面的Mapper接口都将被搜索到,并把它们注册为一个个MapperFactoryBean对象。多个包之间可以使用逗号或者分号进行分隔。

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

    <property name="basePackage" value="org.tarena.mapper"/>

  </bean>

注意:sqlSessionFactory属性可以不用指定,会以Autowired方式自动注入

  MapperScannerConfigurer定义示例:

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

    <property name="basePackage" value="org.tarena"/>

    <property name="annotationClass" value="org.tarena.annotation.MyBatisRepository"/>

  </bean>

  上面配置定义:MapperScannerConfigurer自动扫描org.tarena包下所有接口,遇到带@MyBatisRepository标记的将对应MapperFactoryBean对象注册。

4.SqlSessionTemplate

  上述整合完成后,程序可直接使用Spring容器中的Mapper接口实例进行编程。此外,mybatis-spring.jar还提供了一个SqlSessionTemplate组件,也可以将该组件注入给程序中的DAO,在DAO中利用SqlSessionTemplate编程。

  基于SqlSessionTemplate的DAO示例代码如下

  @Repository

  public class MyBatisDeptDAO implements DeptDAO{

  private SqlSession Template template;

  @Autowired

  public void setTemplate(SqlSession Template template){

  this.template=template;

  }

  public List<Dept> findAll(){

  List<Dept> list= template.selectList("findAll");

  return list;

  }

  }

  基于SqlSessionTemplate的DAO配置信息如下:

  <!-- 定义SqlSessionTemplate -->

  <bean id="sqlSessionTemplate" class="org.mybatis.spring.SqlSessionTemplate">

    <constructor-arg  index="0" ref="sqlSessionFactory"/>

  </bean>

  <!-- 扫描DAO并注入template -->

  <context:component-scan base-package="org.tarena.dao"/>

  <bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">

  </bean>

    

整合步骤介绍

  基于SpringMVC和MyBatis技术开发的主要步骤如下:

  1.创建工程,搭建SpringMVC和MyBatis技术环境

    1)创建一个Web工程

     2)添加MyBatis相关技术环境

      -引入数据库驱动包和MyBatis开发包

      -引入dbcp连接池开发包

    3)添加SpringMVC相关技术环境

      -引入Spring IOC,JDBC,TX等支持的开发包

      -引入Spring webmvc支持的开发包

        

      -在src下添加applicationContext.xml配置文件

      -在web.xml中配置DispatcherServlet主控制器

    4)引入MyBatis和Spring整合开发包mybatis-spring.jar  

  2.基于MapperScannerConfigurer方式整合MyBatis的Mapper接口(推荐)

     1)根据数据表编写实体类

    2)编写Mapper映射文件,在XML中添加SQL操作的定义

    3)编写Mapper接口,定义SQL操作方法

    4)在Spring配置文件中定义以下Bean

      -DataSource

      -SqlSessionFactoryBean

      -MapperScannerConfigurer

    5)测试Spring容器的DAO组件

  3.编写和配置SpringMVC的主要组件,例如:Controller,HandlerMapping,ViewResolver等

     1)编写Controller和请求处理方法

    2)配置<mvc:annotation-driven/>,支持@RequestMapping

    3)配置Controller组件

      -开启组件扫描,将Controller扫描到Spring容器

      -需要DAO时采用注入方式使用

      -在请求处理方法上使用@RequestMapping指定对应的请求

    4)配置ViewResolver组件

  4.编写JSP视图组件,利用标签和表达式显示模型数据

     1)JSP可以使用JSTL标签库,需要引入开发包

    2)JSP可以使用EL表达式

    3)JSP可以使用SpringMVC的表单标签

  5.测试程序

spring mvc mybatis的更多相关文章

  1. spring Mvc + Mybatis 中使用junit

    在Spring Mvc + Mybatis的项目中我们有时候需要在测试代码中注入Dao操作数据库,对表进行增删改查,实现如下: 这是一般的maven项目项目结构 测试代码一般写在src/test/ja ...

  2. 基于Spring + Spring MVC + Mybatis + shiro 高性能web构建

    一直想写这篇文章,前段时间 痴迷于JavaScript.NodeJs.AngularJS,做了大量的研究,对前后端交互有了更深层次的认识. 今天抽个时间写这篇文章,我有预感,这将是一篇很详细的文章,详 ...

  3. spring + spring mvc + mybatis + react + reflux + webpack Web工程例子

    前言 最近写了个Java Web工程demo,使用maven构建: 后端使用spring + spring mvc + mybatis: 前端使用react + react-router+ webpa ...

  4. spring mvc+mybatis+多数据源切换

    spring mvc+mybatis+多数据源切换,选取oracle,mysql作为例子切换数据源.oracle为默认数据源,在测试的action中,进行mysql和oracle的动态切换. web. ...

  5. Spring3 + Spring MVC+ Mybatis 3+Mysql 项目整合(注解及源码)

    Spring3 + Spring MVC+ Mybatis 3+Mysql 项目整合(注解及源码) 备注: 之前在Spring3 + Spring MVC+ Mybatis 3+Mysql 项目整合中 ...

  6. [转]基于Spring + Spring MVC + Mybatis 高性能web构建

    http://blog.csdn.net/zoutongyuan/article/details/41379851/ 一直想写这篇文章,前段时间 痴迷于JavaScript.NodeJs.Angula ...

  7. Spring+Spring MVC+MyBatis

    Spring+Spring MVC+MyBatis 目录 一.新建一个基于Maven的Web项目 二.创建数据库与表 三.添加依赖包 四.新建POJO实体层 五.新建MyBatis SQL映射层 六. ...

  8. 基于Spring + Spring MVC + Mybatis 高性能web构建

    基于Spring + Spring MVC + Mybatis 高性能web构建 一直想写这篇文章,前段时间 痴迷于JavaScript.NodeJs.AngularJs,做了大量的研究,对前后端交互 ...

  9. maven/eclipse搭建ssm(spring+spring mvc+mybatis)

    maven/eclipse搭建ssm(spring+spring mvc+mybatis) 前言 本文旨在利用maven搭建ssm环境,而关于maven的具体内容,大家可以去阅读<Maven 实 ...

  10. java企业架构 spring mvc +mybatis + KafKa+Flume+Zookeeper

    声明:该框架面向企业,是大型互联网分布式企业架构,后期会介绍linux上部署高可用集群项目. 项目基础功能截图(自提供了最小部分)      平台简介        Jeesz是一个分布式的框架,提供 ...

随机推荐

  1. IOS UIColor 自定义颜色

    使用 UIColor定义颜色 和 同 CIColor 与  CGColor 之间的联系.转换 1. 利用UIColor展现 #F6F6F6 这个传统的颜色 #F6F6F6 为一个 16 进制表示的RP ...

  2. Singleton 模式

    个人认为 Singleton 模式是设计模式中最为简单.最为常见.最容易实现,也是最应该熟悉和掌握的模式.且不说公司企业在招聘的时候为了考察员工对设计的了解和把握,考的最多的就是 Singleton ...

  3. Asp.net GridView 72般绝技

    快速预览:GridView无代码分页排序GridView选中,编辑,取消,删除GridView正反双向排序GridView和下拉菜单DropDownList结合GridView和CheckBox结合鼠 ...

  4. rel=nofollow 是什么意思

    nofollow是什么意思? nofollow是html标签的一个属性值,Google推荐使用nofollow,告诉机器(爬虫)无需追踪目标页,是指禁止蜘蛛爬行和传递权重,但是如果你是通过sitema ...

  5. 用python选择及显示三级目录,可返回上层目录以及随时跳出。

    # -*- coding: utf-8 -*-"""Created on Fri Jul 29 09:43:38 2016 @author: yinggang" ...

  6. linux下svn客户端报错Cannot negotiate authentication mechanism的解决方法

    svn客户端报错Cannot negotiate authentication mechanism的解决方法: 问题出现的原因之一: 因为SVN服务器配置了saslauthd服务用来实现与ldap的对 ...

  7. android开发学习笔记:圆角的Button

    转自:http://www.cnblogs.com/gzggyy/archive/2013/05/17/3083218.html 在res目录下的drawable-mdpi建立xml文件shape.x ...

  8. SQL Server 2008无日志文件附加数据库

    1.新建一个同名数据库. 2.停止数据库服务,覆盖新建的数据库主文件(小技巧:最好放在同一个磁盘里面,把新建的数据库主文件删掉或移开,再把要恢复的数据库主文件剪切过去,这样就可以节省时间.) 3.启动 ...

  9. c# 無彈窗调用打印机

    using System; using System.Collections.Generic; using System.Text; using System.Configuration; using ...

  10. 排他锁Lock

    using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.T ...