news 2026/3/26 15:19:37

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/3/15 12:55:32

汇编语言全接触-24.WINDOWS钩子函数

本课中我们将要学习WINDOWS钩子函数的使用方法。WINDOWS钩子函数的功能非常强大&#xff0c;有了它您可以探测其它进程并且改变其它进程的行为。 理论&#xff1a;WINDOWS的钩子函数可以认为是WINDOWS的主要特性之一。利用它们&#xff0c;您可以捕捉您自己进程或其它进程发生的…

作者头像 李华
网站建设 2026/3/26 7:07:35

接口中的方法全解析(JDK8-17 演进 + 实战示例)

在之前讲抽象类和接口区别时,我们只提了接口方法的 “大类”,但接口的方法类型远不止 “抽象方法”—— 随着 JDK 版本迭代,接口支持的方法类型越来越丰富,不同方法的定位、用法和注意事项差异极大。今天专门补充接口中所有方法类型的细节,帮你彻底吃透接口方法的设计逻辑…

作者头像 李华
网站建设 2026/3/22 15:55:37

OAuth2 协议解析(安全视角)

RefinitionOAuth2 是在WEB基础上发展出来的一个授权框架&#xff08;Authorization Framework&#xff09;&#xff0c;也可以认为它是一套协议&#xff0c;一套能解决第三方授权问题的解决方案&#xff0c;优势在于它允许第三方应用在不获取用户密码的情况下&#xff0c;获得访…

作者头像 李华
网站建设 2026/3/18 21:33:30

xv6与opensbi的定时器中断

在实现了第一个系统调用myHelloWorld、虚存管理后&#xff0c;为了实现能够做到分时系统的进程管理&#xff0c;我们需要启用定时器中断。 寄存器 为了实现定时器中断&#xff0c;你需要知道(牢记)如下寄存器&#xff0c;这些寄存器是你在处理定时器中断时特别关心的。 scau…

作者头像 李华
网站建设 2026/3/16 2:54:51

Code Surfer终极指南:让代码演示生动起来的完整教程

Code Surfer终极指南&#xff1a;让代码演示生动起来的完整教程 【免费下载链接】code-surfer Rad code slides <&#x1f3c4;/> 项目地址: https://gitcode.com/gh_mirrors/co/code-surfer 还在为枯燥的代码演示而烦恼吗&#xff1f;&#x1f914; 想要让你的技…

作者头像 李华
网站建设 2026/3/15 16:44:19

统计接口耗时的6种常见方法

为什么统计接口耗时如此重要&#xff1f;在深入方法之前&#xff0c;我们先聊聊为什么接口耗时统计这么关键。从架构师的角度看&#xff0c;这不仅仅是“记录一个时间”那么简单。接口耗时直接反映了系统性能&#xff0c;它是&#xff1a;性能优化的基石&#xff1a;没有耗时数…

作者头像 李华