news 2026/6/9 20:04:08

Springboot数据层开发—Springboot整合JdbcTemplate和Mybatis

作者头像

张小明

前端开发工程师

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

Springboot整合JdbcTemplate和Mybatis

  • springboot整合JdbcTemplate
  • Springboot整合Mybatis注解方式
  • Springboot整合Mybatis配置文件方式

本文介绍 SpringBoot 整合 JdbcTemplate 和 MyBatis 两种方式,均都体现了SpringBoot简化数据访问层开发的特性。

springboot整合JdbcTemplate

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

SETFOREIGN_KEY_CHECKS=0;-- ------------------------------ Table structure for user-- ----------------------------DROPTABLEIFEXISTS`user`;CREATETABLE`user`(`username`varchar(10)DEFAULTNULL,`userId`int(10)NOTNULL,`password`varchar(10)DEFAULTNULL,PRIMARYKEY(`userId`))ENGINE=InnoDBDEFAULTCHARSET=utf8;

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

@ControllerpublicclassTestController{@AutowiredJdbcTemplatejdbcTemplate;@ResponseBody@RequestMapping("/query")publicList<Map<String,Object>>query(){List<Map<String,Object>>maps=jdbcTemplate.queryForList("SELECT * FROM user");returnmaps;}}

由于 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

importjava.util.Date;publicclassPerson{privateintpid;privateStringpname;privateStringaddr;privateintgender;privateDatebirth;publicPerson(){}publicPerson(intpid,Stringpname,Stringaddr,intgender,Datebirth){this.pid=pid;this.pname=pname;this.addr=addr;this.gender=gender;this.birth=birth;}publicintgetPid(){returnpid;}publicvoidsetPid(intpid){this.pid=pid;}publicStringgetPname(){returnpname;}publicvoidsetPname(Stringpname){this.pname=pname;}publicStringgetAddr(){returnaddr;}publicvoidsetAddr(Stringaddr){this.addr=addr;}publicintgetGender(){returngender;}publicvoidsetGender(intgender){this.gender=gender;}publicDategetBirth(){returnbirth;}publicvoidsetBirth(Datebirth){this.birth=birth;}@OverridepublicStringtoString(){return"Person{"+"pid="+pid+", pname='"+pname+'\''+", addr='"+addr+'\''+", gender="+gender+", birth="+birth+'}';}}

创建Mapper

importjava.util.List;@MapperpublicinterfacePersonMapper{@Select("select * from person")publicList<Person>getPersons();@Select("select * from person t where t.pid = #{id}")publicPersongetPersonById(intid);@Options(useGeneratedKeys=true,keyProperty="pid")@Insert("insert into person(pid, pname, addr,gender, birth)"+" values(#{pid}, #{pname}, #{addr},#{gender}, #{birth})")publicvoidinsert(Personperson);@Delete("delete from person where pid = #{id}")publicvoidupdate(intid);}

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

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

单元测试

@RunWith(SpringRunner.class)@SpringBootTestpublicclassspringBootMybatisTest{@AutowiredPersonMapperpersonMapper;@TestpublicvoidtestMybatis()throwsSQLException{List<Person>persons=personMapper.getPersons();for(Personperson:persons){System.out.println(person);}}@TestpublicvoidtestMybatis1()throwsSQLException{Personp=personMapper.getPersonById(1);System.out.println(p);}}

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

@ConfigurationpublicclassMybatisConfig{@BeanpublicConfigurationCustomizergetCustomizer(){returnnewConfigurationCustomizer(){@Overridepublicvoidcustomize(org.apache.ibatis.session.Configurationconfiguration){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" ?><!DOCTYPEconfigurationPUBLIC"-//mybatis.org//DTD Config 3.0//EN""http://mybatis.org/dtd/mybatis-3-config.dtd"><configuration><settings><settingname="mapUnderscoreToCamelCase"value="true"/></settings></configuration>

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

创建sql映射文件 PersonMapper.xml

<?xml version="1.0" encoding="UTF-8" ?><!DOCTYPEmapperPUBLIC"-//mybatis.org//DTD Mapper 3.0//EN""http://mybatis.org/dtd/mybatis-3-mapper.dtd"><mappernamespace="com.qcby.springBootMybatis.mapper.PersonMapper"><selectid="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/6/9 21:34:58

9款AI论文工具实测:从开题到成稿一键生成,效率翻倍

毕业论文季如何高效完成开题报告和论文是学生普遍面临的挑战&#xff0c;传统人工写作方式灵活但效率较低&#xff0c;而AI工具能快速生成内容、优化文本重复率并处理AI痕迹。通过对9款主流平台的对比测试&#xff0c;可以筛选出最适合学术场景的智能辅助工具&#xff0c;实测数…

作者头像 李华
网站建设 2026/6/9 13:00:55

10、面向国际受众写作的全面指南

面向国际受众写作的全面指南 在当今全球化的时代,越来越多的商业交易和交流通过互联网进行,互联网是一种国际性的媒介。为计算机行业编写易于翻译成其他语言并能传达给其他国家受众的文档,正成为一项必要任务。以下将为你详细介绍面向国际受众写作时需要遵循的各项准则。 …

作者头像 李华
网站建设 2026/6/9 22:16:52

低轨卫星导航增强技术:改正数播发模式的原理、信号流程和关键指标

低轨卫星导航增强技术&#xff1a;改正数播发模式的原理、信号流程和关键指标 1. GNSS 导航增强技术 1.1 原理 全球卫星导航系统&#xff08;GNSS&#xff09;受卫星轨道误差、卫星钟差、电离层延迟、对流层延迟及码偏差等因素影响&#xff0c;用户终端定位精度通常为米级&…

作者头像 李华
网站建设 2026/6/8 21:31:49

CH340/CH341驱动终极指南:快速解决USB转串口连接问题

CH340/CH341驱动终极指南&#xff1a;快速解决USB转串口连接问题 【免费下载链接】CH340CH341官方驱动最新版WIN1110 本仓库提供CH340/CH341 USB转串口Windows驱动程序的最新版本。该驱动程序支持32/64位 Windows 11/10/8.1/8/7/VISTA/XP&#xff0c;SERVER 2022/2019/2016/201…

作者头像 李华
网站建设 2026/6/9 3:17:35

我店模式上市故事:不靠烧钱,让每一笔消费成为“资产”商业逻辑

上海我店模式2021年推出的本地生活服务平台商业模式&#xff0c;正尝试用一套独特的“绿色积分”体系&#xff0c;重新连接消费者、商家与平台。其核心逻辑并非简单的打折促销&#xff0c;而是构建一个以“消费即投资”为理念&#xff0c; “消费-积分-增值-再消费” 的闭环生态…

作者头像 李华