news 2026/2/9 13:31:16

【Springboot】数据层开发-JdbcTemplate和Mybatis整合

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
【Springboot】数据层开发-JdbcTemplate和Mybatis整合

Springboot整合JdbcTemplate

首先需要在数据库中创建表

SET FOREIGN_KEY_CHECKS=0; -- ---------------------------- -- Table structure for user -- ---------------------------- DROP TABLE IF EXISTS `user`; CREATE TABLE `user` ( `username` varchar(10) DEFAULT NULL, `userId` int(10) NOT NULL, `password` varchar(10) DEFAULT NULL, PRIMARY KEY (`userId`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8;

Springboot中提供了JdbcTemplateAutoConfiguration 的自动配置 org.springframework.boot.autoconfigure.jdbc.JdbcTemplateAutoConfiguration,
JdbcTemplateAutoConfiguration 源码如下:

@Controller public class TestController { @Autowired JdbcTemplate jdbcTemplate; @ResponseBody @RequestMapping("/query") public List<Map<String, Object>> query(){ List<Map<String, Object>> maps = jdbcTemplate.queryForList("SELECT * FROM user"); return maps; } }

由于 Springboot 中提供了 JdbcTemplateAutoConfiguration 的自动配置,直接使用 @Autowired 注解注入即可,启动 springboot,测试访问 http://localhost:8080/query

访问成功

打开监控页面

Springboot整合Mybatis注解方式

导入 mybatis 整合 springboot 模块

<dependency> <groupId>org.mybatis.spring.boot</groupId> <artifactId>mybatis-spring-boot-starter</artifactId> <version>1.3.1</version> </dependency>

com.baomidou.mybatisplus.autoconfigure.MybatisPlusAutoConfiguration

创建JavaBean

import java.util.Date; public class Person { private int pid; private String pname; private String addr; private int gender; private Date birth; public Person() { } public Person(int pid, String pname, String addr, int gender, Date birth) { this.pid = pid; this.pname = pname; this.addr = addr; this.gender = gender; this.birth = birth; } public int getPid() { return pid; } public void setPid(int pid) { this.pid = pid; } public String getPname() { return pname; } public void setPname(String pname) { this.pname = pname; } public String getAddr() { return addr; } public void setAddr(String addr) { this.addr = addr; } public int getGender() { return gender; } public void setGender(int gender) { this.gender = gender; } public Date getBirth() { return birth; } public void setBirth(Date birth) { this.birth = birth; } @Override public String toString() { return "Person{" + "pid=" + pid + ", pname='" + pname + '\'' + ", addr='" + addr + '\'' + ", gender=" + gender + ", birth=" + birth + '}'; } }

创建Mapper

import java.util.List; @Mapper public interface PersonMapper { @Select("select * from person") public List<Person> getPersons(); @Select("select * from person t where t.pid = #{id}") public Person getPersonById(int id); @Options(useGeneratedKeys =true, keyProperty = "pid") @Insert("insert into person(pid, pname, addr,gender, birth)" + " values(#{pid}, #{pname}, #{addr},#{gender}, #{birth})") public void insert(Person person); @Delete("delete from person where pid = #{id}") public void update(int id); }

其中 @Options(useGeneratedKeys =true, keyProperty = “pid”),MyBatis 会获取到自增的 pid,自动赋值给传入的 person 对象的 pid 属性。

@Mapper 用于明确标记 MyBatis 对应的 Mapper 接口,核心职责是为 MyBatis 提供接口识别信号,触发 MyBatis 对接口的解析与动态代理实现类生成;在 Spring Boot 整合 MyBatis的场景下,该动态代理类会被自动注册为 Spring 容器中的 Bean,支持业务代码通过 @Autowired 直接注入使用。

单元测试

@RunWith(SpringRunner.class) @SpringBootTest public class springBootMybatisTest { @Autowired PersonMapper personMapper; @Test public void testMybatis() throws SQLException { List<Person> persons = personMapper.getPersons(); for (Person person : persons) { System.out.println(person); } } @Test public void testMybatis1() throws SQLException { Person p = personMapper.getPersonById(1); System.out.println(p); } }

开启 MyBatis 的下划线转驼峰命名自动映射功能

@Configuration public class MybatisConfig { @Bean public ConfigurationCustomizer getCustomizer(){ return new ConfigurationCustomizer() { @Override public void customize(org.apache.ibatis.session.Configuration configuration) { configuration.setMapUnderscoreToCamelCase(true); } }; } }

当项目中 Mapper 接口数量较多,若在每个 Mapper 接口上逐一添加 @Mapper 注解,会增加重复工作量且不易维护。此时可采用 @MapperScan 注解的批量扫描方案。在 MyBatis 相关配置类或 Spring Boot 主启动类上添加 @MapperScan 注解,指定 Mapper 接口所在的包路径,MyBatis 会自动扫描该路径下所有接口,将其识别为 Mapper 接口,无需额外标注 @Mapper,即可完成动态代理实现类的生成与 Spring Bean 的注册。

Springboot整合Mybatis配置文件方式

classpath:mybatis 下创建 sqlMapConfig.xml 全局配置文件

<?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> <settings> <setting name="mapUnderscoreToCamelCase" value="true"/> </settings> </configuration>

其中 mapUnderscoreToCamelCase 值为 true 用于开启下划线转驼峰命名自动映射功能

创建sql映射文件 PersonMapper.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.qcby.springBootMybatis.mapper.PersonMapper"> <select id="getPersons" resultType="com.qcby.springBootMybatis.bean.Person"> select * from person </select> </mapper>

在 application.yaml 中配置 mybatis 相关配置信息

其中
config-location 值为全局配置文件路径
mapper-locations 值为sql映射文件
type-aliases-package 值为实体类所在包的全路径

测试验证

需要注意的是使用了 Springboot整合Mybatis配置文件的方式,Springboot 整合 Mybatis 注解版也同样会生效

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/2/7 8:56:15

WarcraftHelper终极指南:让经典魔兽在新电脑上完美运行

WarcraftHelper终极指南&#xff1a;让经典魔兽在新电脑上完美运行 【免费下载链接】WarcraftHelper Warcraft III Helper , support 1.20e, 1.24e, 1.26a, 1.27a, 1.27b 项目地址: https://gitcode.com/gh_mirrors/wa/WarcraftHelper 还在为老版本魔兽在新系统上频繁崩…

作者头像 李华
网站建设 2026/2/4 7:28:56

高效演讲时间管理:PPTTimer智能计时器实战手册

在各类演讲场合中&#xff0c;时间把控往往决定着成败。无论是学术汇报、商务演示还是课堂讲解&#xff0c;精准的时间管理能让你的表现更加出色。PPTTimer作为一款专为演讲者设计的智能计时工具&#xff0c;通过悬浮窗口的形式让你在演讲过程中轻松掌握时间节奏&#xff0c;无…

作者头像 李华
网站建设 2026/2/9 8:32:33

Get-cookies.txt-LOCALLY:3分钟掌握浏览器Cookie本地导出终极指南

Get-cookies.txt-LOCALLY&#xff1a;3分钟掌握浏览器Cookie本地导出终极指南 【免费下载链接】Get-cookies.txt-LOCALLY Get cookies.txt, NEVER send information outside. 项目地址: https://gitcode.com/gh_mirrors/ge/Get-cookies.txt-LOCALLY 在日常网络使用中&am…

作者头像 李华
网站建设 2026/2/8 8:00:32

14、利用 Expression Blend 优化用户界面

利用 Expression Blend 优化用户界面 1. 动画基础与操作 在使用 Expression Blend 进行界面设计时,动画是提升用户体验的重要元素。 Storyboard.TargetProperty 用于向故事板指示 Storyboard.TargetName 中指定元素的哪些属性将逐关键帧地应用更改。例如,我们可以指定在…

作者头像 李华
网站建设 2026/2/4 14:31:07

17、Windows Phone传感器应用开发指南

Windows Phone传感器应用开发指南 1. Windows Phone传感器概述 Windows Phone提供了多种传感器,制造商的基本要求包括加速度计、指南针、接近传感器、光线传感器和A - GPS。在当前版本中,可使用的传感器有加速度计(Accelerometer)、指南针(Compass)和陀螺仪(Gyroscope…

作者头像 李华
网站建设 2026/2/8 7:05:49

29、Windows Phone 应用开发中 MVVM 与 Prism 的实现指南

Windows Phone 应用开发中 MVVM 与 Prism 的实现指南 在 Windows Phone 应用开发中,MVVM(Model - View - ViewModel)模式是一种非常实用的架构模式,它能帮助开发者更好地组织代码,实现视图和逻辑的分离。下面将详细介绍如何在 Windows Phone 应用中使用 MVVM Light 以及 P…

作者头像 李华