Spring集成MyBatis框架
发布时间 - 2026-01-10 22:52:45 点击率:次Java在写数据库查询时,我接触过四种方式:

1、纯Java代码,引用对应的数据库驱动包,自己写连接与释放逻辑(可以用连接池)
这种模式实际上性能是非常不错的,但是使用起来并不是非常方便:一是要手工为Connection做获取与释放,大量的冗余代码也容易出错;另一个是,复杂的SQL用字符串写起来简直不可维护(换行、可视长度、参数都是问题)。
2、使用Spring JdbcTemplate
这个其实还是挺不错的,配置比较简单,功能丰富上比手工管理Connection要舒服多了,而且代码也比较简洁。突出的问题就是SQL维护还是挺麻烦的。
3、使用Hibernate框架
一句话,配置很麻烦,用起来还是挺不错的。但是有一个致命缺陷,它并不能像单表查询一样可以帮我们完成多表的查询。如果有复杂的多表查询或查询条件,还是得用SQL去查,这对于一些业务逻辑复杂或者会经常变更的业务来说,后期维护就是灾难,改到想哭(因为真的是很混乱,一定要开始就规划好)。
4、使用MyBatis框架
这个是当前我所做项目最喜欢用的数据库持久化框架了,它通过XML配置可以非常简单直观地帮你完成各种条件、判断、多表的综合查询,实现方式比Java代码拼SQL要舒服太多了,在这方面更是甩Hibernate一条街。要说易用性,其实也挺容易用的,但是配置上也要对一些数据做映射,不过相对而言更加灵活。它的实体类并不一定要是数据库物理表,而可以是任意查询出来的数据集(类似数据传输对象DTO)。
简单总结一下:
配置容易程度:1 > 2 > 4 > 3
使用便捷程度:2 > 3 > 4 > 1
查询灵活程度:4 > 1 = 2 > 3
下面将开始介绍Spring集成MyBatis的配置和使用,项目基于Maven构建,连接Mysql数据库:
一、Maven配置
<!-- Spring Base --> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-beans</artifactId> <version>4.2.5.RELEASE</version> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-context</artifactId> <version>4.2.5.RELEASE</version> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-jdbc</artifactId> <version>4.2.5.RELEASE</version> </dependency> <!-- MySql --> <dependency> <groupId>mysql</groupId> <artifactId>mysql-connector-java</artifactId> <version>5.1.39</version> </dependency> <dependency> <groupId>com.mchange</groupId> <artifactId>c3p0</artifactId> <version>0.9.5.2</version> </dependency> <dependency> <groupId>org.mybatis</groupId> <artifactId>mybatis</artifactId> <version>3.4.1</version> </dependency> <dependency> <groupId>org.mybatis</groupId> <artifactId>mybatis-spring</artifactId> <version>1.3.0</version> </dependency>
关于Spring的包引用,我这里的引用只作为参考,其它web、mvc的包视各业务来引用。如果不用Maven,就自己乖乖引jar包,或者使用其它包管理吧。
二、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.mchange.v2.c3p0.ComboPooledDataSource" destroy-method="close"> <property name="driverClass" value="com.mysql.jdbc.Driver" /> <property name="jdbcUrl" value="jdbc:mysql://xxx.xxx.xxx.xxx:3306/xxxdb" /> <property name="user" value="lekko" /> <property name="password" value="xxx" /> <property name="minPoolSize" value="2" /> <property name="maxPoolSize" value="100" /> </bean> <bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean"> <property name="mapperLocations" value="classpath:mapper/**/*Mapper.xml" /> <property name="dataSource" ref="myDataSource" /> </bean> <bean id="mapperScannerConfigurer" class="org.mybatis.spring.mapper.MapperScannerConfigurer"> <property name="basePackage" value="lekko.code.**.dao" /> </bean> </beans>
这里的配置比较关键。
1、myDataSource是一个ComboPooledDataSource类型的实例bean,它实现了数据库连接池的功能。
2、sqlSessionFactory是MyBatis用于建立查询的工厂实例,它包括了一个mapperLocations定位,以及dataSource数据库连接来源。
- mapperLocations指定了MyBatis将会搜索的路径,支持Ant风格路径。在指定的路径下,MyBatis会把读取其中的xml查询,并将用于后面的dao映射。
- dataSource是来源数据库,这里直接就是前面的连接池。
3、mapperScannerConfigurer是MyBatis用于自动建立数据库dao类的配置器。
- basePackage指定了要扫描的包名称,支持Ant风格路径。在指定的包名称下,MyBatis通过Spring,会自动发现对应包名下的dao接口,在后面需要查询时,为接口提供实现。
下图是MyBatis的大体框架,可以作为上述配置的一个补述:
也就是说,MyBatis会根据XML配置Mapper去组成数据库查询,然后把查询中所涉及的参数、返回结果,都映射成为Java对象(或元数据类型)。最后交由数据库去执行,返回。
三、dao接口
package lekko.code.test.dao;
import lekko.code.test.model.TestModel;
import org.springframework.stereotype.Repository;
/**
* 测试DAO
*/
@Repository
public interface TestDao {
TestModel getTest(String name);
int addTest(String name);
}
上面这个接口,由于属于包lekko.code.**.dao,所以会被识别为需要映射的dao。
接口只有两个方法,一个是查询getTest,一个是新增addTest。至于getTest已经根据需要,我这里提取成了一个实体类TestModel:
package lekko.code.test.model;
/**
* 测试数据类
*/
public class TestModel {
private int id;
private String name;
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public int getId() {
return id;
}
public void setId(int id) {
this.id = id;
}
}
四、Mapper映射
<?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="lekko.code.test.dao.TestDao">
<select id="getTest" resultType="lekko.code.test.model.TestModel">
select id, name from Test where name = #{name}
</select>
<insert id="addTest">
insert into Test (name, createdTime) values (#{name}, now())
</insert>
</mapper>
语法我就不详细解释了,百度一下就有。各种条件、判断、参数都有解释。我本人非常喜欢这种自由度高,sql看起来也很舒服的配置方式。
至此,大体的使用介绍已经完毕。MyBatis还是挺不错的,建议大家在业务合适的情况下试用试用。
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持!
# Spring
# MyBatis
# 详解Http请求中Content-Type讲解以及在Spring MVC中的应用
# 深入理解Spring Boot的日志管理
# spring mvc中的@PathVariable获得请求url中的动态参数
# Spring Boot统一异常处理详解
# 详解Spring中的JavaConfig注解
# SpringMVC实现controller中获取session的实例代码
# SpringMVC实现注解式权限验证的实例
# spring mvc 和ajax异步交互完整实例代码
# Spring中@Async用法详解及简单实例
# 连接池
# 的是
# 都是
# 数据库查询
# 是一个
# 我就
# 都有
# 成了
# 将会
# 在这
# 就有
# 一是
# 可以用
# 帮你
# 最喜欢
# 也很
# 并将
# 实体类
# 要对
# 所做
相关栏目:
【
网站优化151355 】
【
网络推广146373 】
【
网络技术251813 】
【
AI营销90571 】
相关推荐:
Python面向对象测试方法_mock解析【教程】
如何在IIS中新建站点并配置端口与物理路径?
Win11怎么恢复误删照片_Win11数据恢复工具使用【推荐】
微信小程序 input输入框控件详解及实例(多种示例)
laravel怎么用DB facade执行原生SQL查询_laravel DB facade原生SQL执行方法
悟空浏览器如何设置小说背景色_悟空浏览器背景色设置【方法】
,怎么在广州志愿者网站注册?
如何快速搭建高效服务器建站系统?
Laravel如何发送邮件_Laravel Mailables构建与发送邮件的简明教程
微信小程序制作网站有哪些,微信小程序需要做网站吗?
移动端手机网站制作软件,掌上时代,移动端网站的谷歌SEO该如何做?
如何在宝塔面板创建新站点?
Laravel Telescope怎么调试_使用Laravel Telescope进行应用监控与调试
网站制作价目表怎么做,珍爱网婚介费用多少?
Laravel Blade组件怎么用_Laravel可复用视图组件的创建与使用
Win11怎么更改系统语言为中文_Windows11安装语言包并设为显示语言
网站视频制作书签怎么做,ie浏览器怎么将网站固定在书签工具栏?
Laravel如何使用Livewire构建动态组件?(入门代码)
Python3.6正式版新特性预览
ai格式如何转html_将AI设计稿转换为HTML页面流程【页面】
laravel服务容器和依赖注入怎么理解_laravel服务容器与依赖注入解析
Laravel如何集成Inertia.js与Vue/React?(安装配置)
海南网站制作公司有哪些,海口网是哪家的?
Laravel怎么实现验证码功能_Laravel集成验证码库防止机器人注册
laravel怎么为应用开启和关闭维护模式_laravel应用维护模式开启与关闭方法
如何构建满足综合性能需求的优质建站方案?
文字头像制作网站推荐软件,醒图能自动配文字吗?
简单实现Android文件上传
JavaScript如何实现路由_前端路由原理是什么
制作电商网页,电商供应链怎么做?
如何快速搭建虚拟主机网站?新手必看指南
Bootstrap整体框架之JavaScript插件架构
Python企业级消息系统教程_KafkaRabbitMQ高并发应用
北京网站制作的公司有哪些,北京白云观官方网站?
googleplay官方入口在哪里_Google Play官方商店快速入口指南
高防服务器租用如何选择配置与防御等级?
EditPlus中的正则表达式 实战(2)
深圳网站制作的公司有哪些,dido官方网站?
Laravel怎么创建自己的包(Package)_Laravel扩展包开发入门到发布
今日头条微视频如何找选题 今日头条微视频找选题技巧【指南】
Laravel怎么做缓存_Laravel Cache系统提升应用速度的策略与技巧
JavaScript如何实现错误处理_try...catch如何捕获异常?
Midjourney怎么调整光影效果_Midjourney光影调整方法【指南】
Laravel如何监控和管理失败的队列任务_Laravel失败任务处理与监控
Laravel如何使用Seeder填充数据_Laravel模型工厂Factory批量生成测试数据【方法】
香港代理服务器配置指南:高匿IP选择、跨境加速与SEO优化技巧
如何在阿里云部署织梦网站?
Laravel如何使用Gate和Policy进行授权?(权限控制)
Laravel任务队列怎么用_Laravel Queues异步处理任务提升应用性能
Laravel Sail是什么_基于Docker的Laravel本地开发环境Sail入门

