spring——整合Mybatis
一、Mybatis整合spring
步骤:
- 导入相关jar包
- junit
- mybatis
- mysql数据库
- spring-webmvc
- aop织入
- mybatis-spring
- spring-jdbc(spring的事务管理器,也可以用druid等的代替)
- 编写配置文件
- 测试
1.1 回忆mybatis
- 编写实体类
- 编写核心配置文件
- 编写接口
- 编写Mapper.xml
- 测试
1.2 整合方式一
注意版本限制:

dataSource(这里配置使用Spring的数据源替换Mybatis的配置)
<bean id="dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource">
<property name="driverClassName" value="com.mysql.jdbc.Driver"/>
<property name="url" value="jdbc:mysql://localhost:3306/dailyClick-test?useSSL=false&useUnicode=true&characterEncoding=utf-8"/>
<property name="username" value="1111"/>
<property name="password" value="1111"/>
</bean>
注:Mybatis有默认的数据源(连接池),但是是可以替换的
sqlSessionFactory配置
<bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
<property name="dataSource" ref="dataSource" />
<!-- 绑定配置文件地址和mapper地址-->
<property name="configLocation" value="classpath:mybatis-config.xml"/>
<property name="mapperLocations" value="classpath:com/guan/dao/*.xml"/>
</bean>
注意:
- 需要配置数据源
- 需要绑定配置文件地址和mapper地址,注意这里的路径使用classpath路径
- 由于mapper等信息被转移到
<bean>中,不能重复配置(如:<mapper>),否则会报错;mybatis-config.xml配置文件通常留<typeAlias>和<settings>
与在原来的mybatis不同,整合后需要有一个接口的实现类,且接口的方法需要通过sqlSessionTemplate实现(有利于bean的注册和管理,这个sqlSessioinTemplate是线程安全的)
sqlSessionTemplate配置
<bean id="sqlSession" class="org.mybatis.spring.SqlSessionTemplate">
<constructor-arg index="0" ref="sqlSessionFactory"/>
</bean>
注:由于sqlSessionTemplate没有set方法,只有构造函数,所以通过
<constructor>标签注入实现类:与mybatis元素代码不同,接口类需要实现且接口的方法通过sqlSessionTemplate实现
public class UserMapperImpl implements UserMapper {
SqlSessionTemplate sqlSession; public void setSqlSession(SqlSessionTemplate sqlSession) {
this.sqlSession = sqlSession;
} public List<UserBean> getUserList() {
UserMapper mapper = sqlSession.getMapper(UserMapper.class);
return mapper.getUserList();
}
}
<bean id="userMapper" class="com.guan.dao.UserMapperImpl">
<property name="sqlSession" ref="sqlSession"/>
</bean>
测试
public class MyTest {
public static void main(String[] args) throws IOException {
ApplicationContext context = new ClassPathXmlApplicationContext("applicationContext.xml");
UserMapperImpl userMapperImpl = context.getBean("userMapper", UserMapperImpl.class);
List<UserBean> userList = userMapperImpl.getUserList();
for (UserBean userBean : userList) {
System.out.println(userBean);
}
}
}
注:
(1).mybatis的配置文件(指的是和spring注册的那一部分),最好通过import引入ApplicationiContext中,这样spring配置文件的结构可以区分开
(2).xxxTemplate是spring特有的模板类
1.3 整合方式二
注:SqlSessionDaoSupport:抽象类,可以通过SqlSessionFactory获得一个SqlSessionTemplate.所以该方法相对于第一种方法增加了一个抽象类,减少了一个配置SqlSessionTemplate的步骤
环境搭建:
接口:
public interface UserMapper1 {
List<UserBean> getUserList();
}
xml实现
<?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="com.guan.dao.UserMapper1">
<select id="getUserList" resultType="userBean">
SELECT * FROM user;
</select>
</mapper>
实体类:
public class UserMapper1Impl extends SqlSessionDaoSupport implements UserMapper1{
public List<UserBean> getUserList() {
return getSqlSession().getMapper(UserMapper1.class).getUserList();
}
}
xml配置(在上文的前文的基础上配置)
<bean id="userMapper1" class="com.guan.dao.UserMapper1Impl">
<property name="sqlSessionFactory" ref="sqlSessionFactory"/>
</bean>
测试:
public static void main(String[] args) throws IOException {
ApplicationContext context = new ClassPathXmlApplicationContext("applicationContext.xml");
UserMapper1Impl userMapperImpl = context.getBean("userMapper1", UserMapper1Impl.class);
List<UserBean> userList = userMapperImpl.getUserList();
for (UserBean userBean : userList) {
System.out.println(userBean);
}
}
二、spring中的事物管理
编程式事务:将事务管理代码嵌到业务方法中控制事务的提交和回滚
缺点:使业务逻辑中包含额外的事务管理代码
声明式事物:使用AOP
(1).搭建环境:
接口
public interface UserMapper1 {
List<UserBean> getUserList();
void insert(UserBean user);
void delete(String UId);
}
mapper:
<insert id="insert" parameterType="userBean">
INSERT INTO user(UId,UName,USet,UAuth,UPassword,UState) VALUES(#{UId},#{UName},#{USet},#{UAuth},#{UPassword},#{UState});
</insert> <delete id="delete" parameterType="string">
DELETEs FROM user WHERE UId = #{UId};
</delete>
注:可以看到我这里的"DELETEs"是错误的写法
编写实体类:
public class UserMapper1Impl extends SqlSessionDaoSupport implements UserMapper1{
public List<UserBean> getUserList() {
insert(new UserBean("6666666666","淀真嗣",1,0,"123456",1));
delete("3180421016");
return getSqlSession().getMapper(UserMapper1.class).getUserList();
} public void insert(UserBean user) {
getSqlSession().getMapper(UserMapper1.class).insert(user);
} public void delete(String UId) {
getSqlSession().getMapper(UserMapper1.class).delete(UId);
}
}
注:getUserList中添加了insert和delete方法,且delete方法是错误的.如果没有事务,则插入可以完成;如果有事务,则插入无法完成
(2).导入事务相关的xml头文件约束,创建
DataSourceTransaction对象以开启事务,配置事务通知,结合AOP实现事务的织入<?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:tx="http://www.springframework.org/schema/tx"
xmlns:aop="http://www.springframework.org/schema/aop"
xsi:schemaLocation="http://www.springframework.org/schema/beans
https://www.springframework.org/schema/beans/spring-beans.xsd
http://www.springframework.org/schema/tx
https://www.springframework.org/schema/tx/spring-tx.xsd http://www.springframework.org/schema/aop https://www.springframework.org/schema/aop/spring-aop.xsd"> <bean id="dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource">
<property name="driverClassName" value="com.mysql.jdbc.Driver"/>
<property name="url" value="jdbc:mysql://47.100.90.132:3306/dailyClick-test?useSSL=false&useUnicode=true&characterEncoding=utf-8"/>
<property name="username" value="root"/>
<property name="password" value="aguan123"/>
</bean> <bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
<property name="dataSource" ref="dataSource" />
<!-- bind mybatis-config.xml and userMapper.xml-->
<property name="configLocation" value="classpath:mybatis-config.xml"/>
<property name="mapperLocations" value="classpath:com/guan/dao/*.xml"/>
</bean> <bean id="userMapper1" class="com.guan.dao.UserMapper1Impl">
<property name="sqlSessionFactory" ref="sqlSessionFactory"/>
</bean> <!-- 配置声明式事务-->
<bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
<property name="dataSource" ref="dataSource"/>
</bean> <!-- 配置事务通知-->
<tx:advice id="txAdvice" transaction-manager="transactionManager">
<tx:attributes>
<tx:method name="getUserList" propagation="REQUIRED"/>
</tx:attributes>
</tx:advice> <!-- 结合AOP织入事务-->
<aop:config>
<aop:pointcut id="point" expression="execution(* com.guan.dao.*.*(..))"/>
<!-- <aop:advisor advice-ref="txAdvice" pointcut-ref="point"/>-->
</aop:config> </beans>
注:
<tx:method name="getUserList" propagation="REQUIRED"/>的propagation属性表示对这些方法怎样使用事务,如:REQUIRED表示支持当前事务,如果当前没有事务,就新建一个事务 (Default)(3).测试
public class MyTest { public static void main(String[] args) throws IOException {
ApplicationContext context = new ClassPathXmlApplicationContext("applicationContext.xml");
UserMapper1 userMapperImpl = context.getBean("userMapper1", UserMapper1.class);
List<UserBean> userList = userMapperImpl.getUserList();
for (UserBean userBean : userList) {
System.out.println(userBean);
}
}
}
注意:由于使用了AOP,这里
UserMapper1 userMapperImpl = context.getBean("userMapper1", UserMapper1.class)的返回类型必须为interface类型,而不是实体类型
spring——整合Mybatis的更多相关文章
- Spring学习总结(六)——Spring整合MyBatis完整示例
为了梳理前面学习的内容<Spring整合MyBatis(Maven+MySQL)一>与<Spring整合MyBatis(Maven+MySQL)二>,做一个完整的示例完成一个简 ...
- Spring学习总结(五)——Spring整合MyBatis(Maven+MySQL)二
接着上一篇博客<Spring整合MyBatis(Maven+MySQL)一>继续. Spring的开放性和扩张性在J2EE应用领域得到了充分的证明,与其他优秀框架无缝的集成是Spring最 ...
- 分析下为什么spring 整合mybatis后为啥用不上session缓存
因为一直用spring整合了mybatis,所以很少用到mybatis的session缓存. 习惯是本地缓存自己用map写或者引入第三方的本地缓存框架ehcache,Guava 所以提出来纠结下 实验 ...
- 2017年2月16日 分析下为什么spring 整合mybatis后为啥用不上session缓存
因为一直用spring整合了mybatis,所以很少用到mybatis的session缓存. 习惯是本地缓存自己用map写或者引入第三方的本地缓存框架ehcache,Guava 所以提出来纠结下 实验 ...
- spring整合mybatis错误:class path resource [config/spring/springmvc.xml] cannot be opened because it does not exist
spring 整合Mybatis 运行环境:jdk1.7.0_17+tomcat 7 + spring:3.2.0 +mybatis:3.2.7+ eclipse 错误:class path reso ...
- spring 整合Mybatis 《报错集合,总结更新》
错误:java.lang.NoClassDefFoundError: org/aspectj/weaver/reflect/ReflectionWorld$ReflectionWorldExcepti ...
- spring整合mybatis(hibernate)配置
一.Spring整合配置Mybatis spring整合mybatis可以不需要mybatis-config.xml配置文件,直接通过spring配置文件一步到位.一般需要具备如下几个基本配置. 1. ...
- spring 整合 mybatis 中数据源的几种配置方式
因为spring 整合mybatis的过程中, 有好几种整合方式,尤其是数据源那块,经常看到不一样的配置方式,总感觉有点乱,所以今天有空总结下. 一.采用org.mybatis.spring.mapp ...
- Mybatis学习(六)————— Spring整合mybatis
一.Spring整合mybatis思路 非常简单,这里先回顾一下mybatis最基础的根基, mybatis,有两个配置文件 全局配置文件SqlMapConfig.xml(配置数据源,全局变量,加载映 ...
- Spring整合MyBatis 你get了吗?
Spring整合MyBatis 1.整体架构dao,entity,service,servlet,xml 2..引入依赖 <dependencies> <dependency> ...
随机推荐
- [杭电新生赛]hgame-week1-web-wp
hgame第一周总结 (官方wp更加简洁明了.直入主题,个人比较菜,所以过程繁琐 写好了一直没发qwq(就是懒(bushi) 一.Tetris plus! 题目里说玩到3000分就给flag,还真有点 ...
- Spring-BeanFactory体系介绍
1 BeanFactory介绍 BeanFactory是Spring中的根容器接口,所有的容器都从从它继承而来,ApplicationContext中对于BeanDefinition的注册,bean实 ...
- 我们一起来学Shell - shell的数组
文章目录 什么是数组 数组中常用变量 数组的定义 小括号定义数组变量 小括号加键值对定义数组变量 分别定义数组变量 动态地定义数组变量 数组赋值的切片 遍历数组 关联数组 我们一起来学Shell - ...
- netty系列之:Bootstrap,ServerBootstrap和netty中的实现
目录 简介 Bootstrap和ServerBootstrap的联系 AbstractBootstrap Bootstrap和ServerBootstrap 总结 简介 虽然netty很强大,但是使用 ...
- 实际项目中使用CompletionService提升系统性能的一次实践
随着互联网应用的深入,很多传统行业也都需要接入到互联网.我们公司也是这样,保险核心需要和很多保险中介对接,比如阿里.京东等等.这些公司对于接口服务的性能有些比较高的要求,传统的核心无法满足要求,所以信 ...
- Java的Future接口
Java的Future接口 Java 中的 Future 接口和其实现类 FutureTask,代表了异步计算的结果. 1. Future接口简介 Future 是异步计算结果的容器接口,它提供了下面 ...
- PDF太大怎么办?缩小PDF的4种常用方法
PDF太大怎么变小?我们在平时学习或生活中经常需要上传或提交一些资料,现在网站都是默认需要提交PDF格式的电子文档,有时提交资料会提示超过系统大小,如何才能使PDF缩小呢? 一.在线压缩 首先搜索sp ...
- 智能化管理工具:商业智能BI
BI(商业智能)是在ERP等信息化管理工具的基础上提出的,是基于信息技术构建的智能化管理工具,它实时地对ERP.CRM.SCM等管理工具生成的企业数据进行各种分析,并给出报告,帮助管理者认识企业和市 ...
- Spring Cloud Sleuth 和 Zipkin 进行分布式跟踪使用指南
分布式跟踪允许您跟踪分布式系统中的请求.本文通过了解如何使用 Spring Cloud Sleuth 和 Zipkin 来做到这一点. 对于一个做所有事情的大型应用程序(我们通常将其称为单体应用程序) ...
- 【基础概念】匹夫细说C#:不是“栈类型”的值类型,从生命周期聊存储位置
转载地址 https://www.cnblogs.com/murongxiaopifu/p/4419040.html 0x00 前言: 匹夫在日常和别人交流的时候,常常会发现一旦讨论涉及到" ...