文档章节

SpringMVC + MyBatis整合

wangbiglei
 wangbiglei
发布于 2015/08/08 22:59
字数 706
阅读 19750
收藏 15

环境:spring3.1.1+mybatis3.2.8+mybatis-spring1.2.3

网络上关于这个架构的搭建文章,实在是太多了,本文是对于本人初次搭建时的一些注意点的整理。

主要是一些配置文件的内容和架构的目录。

0. project 目录

1. spring-resources.xml

这个文件是用来完成spring和mybatis的整合的xml。注意properties文件的读入方式。

<?xml version="1.0" encoding="UTF-8"?>  
<beans xmlns="http://www.springframework.org/schema/beans"  
    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" 
    xmlns:p="http://www.springframework.org/schema/p"  
    xmlns:context="http://www.springframework.org/schema/context"  
    xmlns:tx="http://www.springframework.org/schema/tx"  
    xmlns:aop="http://www.springframework.org/schema/aop"
    xsi:schemaLocation="  
    http://www.springframework.org/schema/beans   
    http://www.springframework.org/schema/beans/spring-beans-3.0.xsd  
    http://www.springframework.org/schema/tx   
    http://www.springframework.org/schema/tx/spring-tx-3.0.xsd   
    http://www.springframework.org/schema/context   
    http://www.springframework.org/schema/context/spring-context-3.0.xsd
    http://www.springframework.org/schema/aop        
    http://www.springframework.org/schema/aop/spring-aop-3.2.xsd" 
	default-autowire="byName" default-lazy-init="false">
	
	<!-- 自动扫描组件,需要把controller去掉,否则影响事务管理 -->  
    <context:component-scan base-package="org.com.mars">  
        <context:exclude-filter type="regex"  
            expression="org.com.mars.controller.*" />  
    </context:component-scan>

	<!-- 引入jdbc配置文件 -->  
    <context:property-placeholder location="classpath:prop/jdbc.properties" /> 

	<!-- (事务管理)transaction manager, use JtaTransactionManager for global tx -->  
    <bean id="transactionManager"  
        class="org.springframework.jdbc.datasource.DataSourceTransactionManager">  
        <property name="dataSource" ref="dataSource" />  
    </bean> 
    
    <!-- 声明式事务管理 -->
    <aop:config>  
        <aop:advisor pointcut="execution(* org.com.mars.service..*.*(..))"  
            advice-ref="myAdvice" />  
    </aop:config>  
    <tx:advice id="myAdvice" transaction-manager="transactionManager">  
        <tx:attributes>  
            <tx:method name="find*" propagation="SUPPORTS" read-only="true" />  
            <tx:method name="query*" propagation="SUPPORTS" read-only="true" />  
            <tx:method name="list*" propagation="SUPPORTS" read-only="true" />  
  
            <tx:method name="create*" propagation="REQUIRED" />  
            <tx:method name="save*" propagation="REQUIRED" />  
            <tx:method name="modify*" propagation="REQUIRED" />  
            <tx:method name="update*" propagation="REQUIRED" />  
            <tx:method name="delete*" propagation="REQUIRED" />  
  
            <tx:method name="*" propagation="SUPPORTS" read-only="true" />  
        </tx:attributes>  
    </tx:advice>  
    
    <!-- 创建SqlSessionFactory,同时指定数据源 -->  
    <bean id="mySqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">  
        <property name="dataSource" ref="dataSource" />  
        <!-- 自动扫描entity目录, 省掉Configuration.xml里的手工配置 -->
        <property name="mapperLocations" value="classpath*:maper/*.map.xml" />
    </bean> 
    
    <!-- DAO接口所在包名,Spring会自动查找其下的类 --> 
    <bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">  
        <property name="basePackage" value="org.com.mars.dao" />
        <property name="sqlSessionFactoryBeanName" value="mySqlSessionFactory" />
    </bean>
    
    <!-- 可通过注解控制事务 -->  
    <tx:annotation-driven />
    
    <!-- 数据库连接池 -->
	<bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource"
		destroy-method="close">
		<!-- Connection Info -->
		<property name="driverClassName" value="${jdbc.driver}" />
		<property name="url" value="${jdbc.url}" />
		<property name="username" value="${jdbc.username}" />
		<property name="password" value="${jdbc.password}" />

		<!-- Connection Pooling Info -->
		<property name="maxActive" value="${dbcp.maxActive}" />
		<property name="maxIdle" value="${dbcp.maxIdle}" />
		<property name="defaultAutoCommit" value="false" />
		<!-- 配置间隔多久才进行一次检测,检测需要关闭的空闲连接,单位是毫秒 -->
		<property name="timeBetweenEvictionRunsMillis" value="3600000" />
		<!-- 配置一个连接在池中最小生存的时间,单位是毫秒 -->
		<property name="minEvictableIdleTimeMillis" value="3600000" />
	</bean>
</beans>

2. mapper.xml

该xml 如何使用配置,请参看spring-resources.xml,注意mapper.xml中 namespace的配置。

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" 
"http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="org.com.mars.dao.test.UserDao">

 <!-- mapping -->
 <resultMap id="User_t" type="org.com.mars.pojo.test.User">
 <result property="userId" column="user_id" jdbcType="VARCHAR" />
 <result property="userName" column="user_name" jdbcType="VARCHAR" />
 </resultMap>

 <sql id="columns">
 user_id,
 user_name
 </sql>


 <!-- 根据ID查询用户信息 -->
 <select id="queryUserById" resultMap="User_t">
 SELECT
 <include refid="columns" />
 FROM
 user_t
 WHERE
 user_id = #{userId}
 </select>

</mapper>

springmvc + mybatis整合详细,及遇到的问题请参看以下资料:

参考资料:

http://www.itnose.net/detail/6074493.html

http://my.oschina.net/wangbiglei/blog/489583

http://my.oschina.net/wangbiglei/blog/489604

感谢热心的前辈!!本文如有不正,请指出。

以上。

© 著作权归作者所有

wangbiglei
粉丝 2
博文 20
码字总数 7737
作品 0
无锡
程序员
私信 提问
加载中

评论(4)

忙碌的小二
忙碌的小二
MyBatis+Spring+Spring MVC整合开发
课程观看地址:http://www.xuetuwuyou.com/course/65
课程出自学途无忧网:http://www.xuetuwuyou.com

课程介绍
一、课程用到的软件:
1、jdk 1.8
2、eclispe luna
3、tomcat 8
4、MySQL 5.1 +
5、navicat 9 +


二、课程涉及到的技术点
1、MyBatis基础,主要介绍
2、MyBatis高级,
3、SpringMVC基础
4、SpringMVC高级
5、MyBatis+SpringMVC整合开发


三、课程目标
1、熟练掌握MyBatis框架
2、熟练掌握Spring MVC框架
3、熟练掌握MyBatis+Spring MVC整合开发

四、课程大纲:
课时1:mybatis简介
课时2: mybatis快速入门
课时3: mybatis-CRUD操作
课时4: mybatis-Dao模式一
课时5: mybatis-Dao模式二
课时6: mybatis-输入输出映射
课时7: mybatis-多对一映射
课时8: mybatis-一对多映射
课时9: mybatis-延时加载
课时10: mybatis-sql片段与模糊查询
课时11: mybatis-一级缓存
课时12: mybatis-二级缓存
课时13: mybatis-与spring整合
课时14: springmvc-简介
课时15: springmvc-原理
课时16: springmvc-入门程序(一)
课时17: springmvc-入门程序(二)
课时18: ssm整合(一)
课时19: ssm整合(二)
课时20: ssm整合(三)
课时21: springmvc-返回值
课时22: springmvc-参数绑定
课时23: springmvc-数据校验
课时24: springmvc-数据回显
课时25: springmvc-异常处理
课时26: springmvc-文件上传
课时27: springmvc-json
课时28: springmvc-RESTful风格
课时29: springmvc-拦截器
i
itxx2016
推荐国内[最著名]的mybatis代码生成网站 --- fwjava.com
不错,学习了
楼主总结的很好,给大家推荐一个:http://blog.sina.com.cn/s/blog_150df94af0102vngn.html
spring springmvc mybatis maven 项目整合示例-导航页面

spring原理 实践解析-简单的helloworld spring原理案例-基本项目搭建 01 spring framework 下载 官网下载spring jar包 spring原理案例-基本项目搭建 02 spring jar包详解 spring jar包的用途...

noteless
2018/06/29
0
0
Mybatis应用学习(6)——Spring框架整合与逆向工程

与Spring框架整合 1. 整合思路: 需要spring通过单例方式管理SqlSessionFactory。 spring和mybatis整合生成代理对象,使用SqlSessionFactory创建SqlSession。(spring和mybatis整合自动完成)...

江左煤郎
2018/11/27
0
0
Spring与MyBatis整合

序言 在MyBatis学习中,我们会发现很多重复性的代码,例如: //创建连接 private SqlSessionFactory sqlSessionFactory = SessionFactoryUtils .getSessionfactory().getSqlSessionFactory(......

开源俱乐部
2014/07/09
0
0
springmvc学习笔记(6)-springmvc整合mybatis(IDEA中通过maven构建

springmvc学习笔记(6)-springmvc整合mybatis(IDEA中通过maven构建) 标签: springmvc mybatis [TOC] 本文主要展示如何在intellij IDEA中通过maven构建springmvc+mybatis框架的开发环境。 需求...

brianway
2016/03/10
432
0
MyBatis系列目录--7. Mybatis与Spring最佳整合

转载请注明出处哈:http://carlosfu.iteye.com/blog/2238662 1. 整合思路 (1) SqlSessionFactory由Spring作为单例管理 (2) spring和mybatis整合生成代理对象,使用SqlSessionFactory创建SqlSe...

付磊-起扬
2015/09/03
0
0

没有更多内容

加载失败,请刷新页面

加载更多

趣谈预留实例券,一文搞懂云上省钱最新玩法

摘要: 一文搞懂时髦的预留实例券(RI) ECS近期推出了预留实例券(Reserved Instances),简称RI,这东西很cool,今天我们聊聊这个。 首先这篇Blog不是文档,读完后想详细了解文档的朋友请点...

zhaowei121
14分钟前
0
0
js 将json字符串转换为json对象的方法解析

js 将json字符串转换为json对象的方法解析 将json字符串转换为json对象的方法。在数据传输过程中,json是以文本,即字符串的形式传递的,而JS操作的是JSON对象,所以,JSON对象和JSON字符串之...

城市之雾
14分钟前
1
0
国外青少年最喜爱的聊天 app,竟然是 Google Docs

简评: 这还真不是标题党,Google Docs 的协作中内置了实时聊天的功能,也可以进行 comments,颇有种现代「传纸条」的既视感。其实国内的石墨文档、腾讯文档等协作工具也有类似的效果,本文很...

极光推送
19分钟前
0
0
用zuul将微服务的多个swagger api文档聚合成一个文档

1.在每个服务的pom中添加以下依赖 <dependency> <groupId>io.springfox</groupId> <artifactId>springfox-swagger2</artifactId></dependency> 注意:仅仅需要添加这个就行。zuul负......

xtof
20分钟前
0
0
为什么取不到metamask的账号?

当你使用Metamask测试以太坊DApp时,如果出现莫名其妙的问题,检查一下web3.eth.accounts是否可以获取到账户,如果不能获取的话,那么最大的可能是你使用了新版的Metamask,并且默认启用了隐...

汇智网教程
21分钟前
0
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部