Spring和MyBatis框架整合
Spring集成MyBatis
使用MyBatis,需要创建MyBatis框架中的某些对象,使用这些对象,就能使用mybatis提供的功能了。
- 需要有Dao接口的代理对象,例如StudentDao接口,需要一个他的代理对象,使用
SqlSession.getMapper(StudentDao.class),得到dao代理对象。 - 需要由SqlSessionFactory,创建SqlSessionFactory才能使用openSession得到SqlSession对象。
- 在处理大型项目的时候,MyBatis提供的数据源(PooledDataSource)难以满足项目需求,通常会更换一个连接池对象。
| Spring容器 (面对Spring开发,从Spring中获得对象) |
|---|
| DataSource对象,数据源 SqlSessionFactory对象 dao接口的代理对象1~n 注:以上对象都由Spring使用IOC创建好对象。 |
实现步骤:
使用msyql数据库,使用学生表student(id int 主键列 自动增长,
name varchar(80) ,
age int )。
创建maven项目
加入依赖:spring依赖,mybatis依赖,mysql驱动,junit依赖,mybatis-spring依赖(mybatis网站上提供的,用来在spring项目中创建mybatis对象),spring事务相关的依赖。
创建实体类Student
创建Dao接口和Mapper文件写SQL语句
写mybatis主配置文件
创建service接口其实现类
创建spring的配置文件
- 声明数据源DataSource,使用阿里的Druid连接池
- 声明SqlSessionFactoryBeanlei,在这个类内部创建的是SqlSessionFactory对象
- 声明MapperScannerConfiguration类,在内部创建dao代理对象,创建的对象都放在spring容器中。
- 声明service对象,将上一步中的dao赋值给service属性,让其进行业务层的操作
测试dao访问数据库
操作
自己建表,三个属性(id(主键),name,age)
创建maven项目(IDEA)
具体依赖:
junit (单元测试)
spring-context (spring依赖)
spring-tx ,spring-jdbc(spring事务的依赖)
mybatis(mybatis依赖)
mybatis-spring(mybatis和spring集成的依赖)
mysql-connector-java(msyql驱动)
druid(阿里连接池)
<!-- resource插件 -->
<build>
<resources>
<resource>
<directory>src/main/java</directory>
<includes>
<include>**/*.properties</include>
<include>**/*.xml</include>
</includes>
<filtering>false</filtering>
</resource>
</resources>
</build>
创建实体类
public class Student {
private Integer id;
private String name;
private Integer age; public Integer getId() {
return id;
} @Override
public String toString() {
return "Student{" +
"id=" + id +
", name='" + name + '\'' +
", age=" + age +
'}';
} public void setId(Integer id) {
this.id = id;
} public String getName() {
return name;
} public void setName(String name) {
this.name = name;
} public Integer getAge() {
return age;
} public void setAge(Integer age) {
this.age = age;
}
}
创建Dao接口和mapper文件
public interface StudentDao { int insertStudent(Student student); List<Student> selectStudents(); }
<!-- -->
<?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.wang.dao.StudentDao"> <insert id="insertStudent">
insert into student(name,age) values(#{name},#{age})
</insert> <select id="selectStudents" resultType="com.wang.domain.Student">
select id,name,age from student
</select> </mapper>
写MyBatis主配置文件
<?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> <typeAliases>
<package name="com.wang.domain"/>
</typeAliases> <!--MyBatis的SQL语句和映射配置文件,指定其他Mapper文件的位置-->
<!-- 找到相应的sql语句-->
<mappers>
<mapper resource="com/wang/dao/StudentDao.xml"/>
</mappers>
</configuration>
创建service接口和实现类
public interface StudentService { int addStudent(Student student); List<Student> queryStudent(); }
public class StudentServiceImpl implements StudentService { private StudentDao studentDao; public void setStudentDao(StudentDao studentDao){
this.studentDao = studentDao;
} @Override
public int addStudent(Student student) {
int i = studentDao.insertStudent(student);
return i;
} @Override
public List<Student> queryStudent() {
List<Student> students = studentDao.selectStudents();
return students;
}
}
创建spring配置文件
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
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.xsd"> <!-- 声明数据源-->
<bean id="myDataSource" class="com.alibaba.druid.pool.DruidDataSource" init-method="init" destroy-method="close">
<property name="url" value="jdbc:mysql://localhost:3306/learnjdbc" />
<property name="username" value="root" />
<property name="password" value="wang" />
</bean> <!-- 声明SqlSessionFactoryBean-->
<bean id="factory" class="org.mybatis.spring.SqlSessionFactoryBean">
<!-- 指定数据源 -->
<property name="dataSource" ref="myDataSource"/> <!-- 指定MyBatis主配置文件 -->
<property name="configLocation" value="classpath:MyBatisConfig.xml" /> </bean> <!-- 声明MapperScannerConfiguration
SqlSession.getMapper(StudentDao.class);
MapperScannerConfigurer作用是:
循环basePackage所表示的包,把保重的每一个接口都找到,调用SqlSession.getMapper()把每个
dao接口都创建出dao对象,dao代理对象放在容器中。
-->
<bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
<!-- 指定SqlSessionFactory对象名称 -->
<property name="sqlSessionFactoryBeanName" value="factory"/>
<!-- 指定基本包,dao接口所在的包名 -->
<property name="basePackage" value="com.wang.dao"/>
</bean> <!-- 声明service-->
<bean id="studentService" class="com.wang.service.impl.StudentServiceImpl">
<property name="studentDao" ref="studentDao"/>
</bean>
</beans>
接下来就可以通过junit进行测试了。
结尾:
- 该过程中的一部分可以使用注解的方式进行(略)
- MyBatis通常使用配置文件的方式,spring通常使用注解的方式
- ssm框架的整合实际上就是MyBatis和spring框架的整合
- 接下来再添加springMvc后,在控制层调用相应的业务处理层即是service的方法就可以实现ssm框架的运行。
Spring和MyBatis框架整合的更多相关文章
- SSM(Spring,SpringMVC,Mybatis)框架整合项目
快速上手SSM(Spring,SpringMVC,Mybatis)框架整合项目 环境要求: IDEA MySQL 8.0.25 Tomcat 9 Maven 3.6 数据库环境: 创建一个存放书籍数据 ...
- SSM(Spring+SpringMVC+MyBatis)框架整合开发流程
回忆了 Spring.SpringMVC.MyBatis 框架整合,完善一个小demo,包括基本的增删改查功能. 开发环境 IDEA MySQL 5.7 Tomcat 9 Maven 3.2.5 需要 ...
- 框架整合——Spring与MyBatis框架整合
Spring整合MyBatis 1. 整合 Spring [整合目标:在spring的配置文件中配置SqlSessionFactory以及让mybatis用上spring的声明式事务] 1). 加入 ...
- Spring+SpringMVC+Mybatis框架整合流程
一:基本步骤 新建Maven项目,导入相关依赖.(推荐) ————–Mybatis配置 —————- 新建entity包,并根据数据库(表)新建相关实体类. 新建dao包,并根据业务创建必要的mapp ...
- SSM Spring SpringMVC Mybatis框架整合Java配置完整版
以前用着SSH都是老师给配好的,自己直接改就可以.但是公司主流还是SSM,就自己研究了一下Java版本的配置.网上大多是基于xnl的配置,但是越往后越新的项目都开始基于JavaConfig配置了,这也 ...
- Spring + Spring MVC + MyBatis框架整合
---恢复内容开始--- 一.Maven Web项目创建 如有需要,请参考:使用maven创建web项目 二.Spring + Spring MVC + MyBatis整合 1.Maven引入需要的J ...
- Spring+Spring MVC+Mybatis 框架整合开发(半注解半配置文件)
项目结构: (代码里面都有注释) 一.在pom文件中依赖jar包 因为我这里分了模块,所以有父子级的共两个pom文件 父级: <?xml version="1.0" enco ...
- Spring+SpringMVC+mybatis框架整合
1.jdbc.properties 1 driverClassName=com.mysql.jdbc.Driver 2 url=jdbc\:mysql\://127.0.0.1\:3306/slsal ...
- spring+springMVC+mybatis框架整合——配置文件说明
如下图 web.xml配置说明: spring配置文件说明-1: spring配置文件说明-2: spring配置助记: 扫注(base) 读配(loc) 数据源(和comb(使用c3p0数据源)) ...
随机推荐
- .NET 云原生架构师训练营(权限系统 RGCA 开发任务)--学习笔记
目录 目标 模块拆分 OPM 开发任务 目标 基于上一讲的模块划分做一个任务拆解,根据任务拆解实现功能 模块拆分 模块划分已经完成了边界的划分,边界内外职责清晰 OPM 根据模块拆分画出 OPM(Ob ...
- Java == 和 equals 的区别(面试描述)
== == 是一个比较运算符 既可以判断基本类型,又可以判断引用类型 如果判断基本数据类型,判断的是值是否相等 如果判断的是引用类型,判断的是地址是否相等,判断是不是同一个对象 equals equa ...
- LibOpenCM3(三) .ld文件(连接器脚本)和startup代码说明
目录 LibOpenCM3(一) Linux下命令行开发环境配置 LibOpenCM3(二) 项目模板 Makefile分析 LibOpenCM3(三) .ld文件(连接器脚本)和startup代码说 ...
- python开启httpserver
- [题解]Codeforces Round #254 (Div. 2) A - DZY Loves Chessboard
链接:http://codeforces.com/contest/445/problem/A 描述:一个n*m的棋盘,有一些格子不能放棋子.现在把黑白棋子往上放,要求放满且相邻格子的棋子颜色不同.输出 ...
- [Unity] 在软件标题栏显示工作路径
(一)问题 项目开发中常会有开多个分支,同时启动多个 Unity 程序的情况,来回切换的时候就容易混淆,有时候还需要用 Show In Explorer 或者其他标志来确认当前使用的是哪个分支. 于是 ...
- Tableau“出走中国”,“卖”给阿里,中国BI用户该何去何从?
11月,Tableau在发给客户的邮件中透露将停止中国的直销业务,加入阿里的合作体系.消息来的如此突然,Tableau的同仁.合作伙伴.客户.用户.爱好者,甚至友商,无一不感到震惊和担忧. 在我们数据 ...
- 【windows 操作系统】协程
◆ 协程 由程序员手动切换. 属于线程,是在线程里面跑的,因此协程又称微线程和线程等.由于不用进行线程上下文切换,因此效率会更高. 资源: 拥有自己的栈空间,大小动态调整. 安全性: 拥有自己的寄存器 ...
- Unicode 详细介绍
总结起来为啥需要Unicodey就是为了适应全球化的发展,便于不同语言之间的兼容交互,而ASCII不再能胜任此任务了 UTF-8 与UTF-16的区别 UTF-8的优缺点 程序员那么到底该如何选择呢? ...
- .NET NuGet整理
分布式缓存框架: Microsoft Velocity:微软自家分布式缓存服务框架. Memcahed:一套分布式的高速缓存系统,目前被许多网站使用以提升网站的访问速度. Redis:是一个高性能的K ...