news 2026/4/23 16:01:03

【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/4/23 9:48:02

34、Windows 8 身份验证方式全解析

Windows 8 身份验证方式全解析 在当今数字化时代,信息安全至关重要。对于 Windows 8 系统而言,拥有多种身份验证方式来保障用户信息安全和系统访问的合法性。下面将详细介绍这些身份验证方式。 智能卡身份验证 智能卡是一种硬件令牌,其中包含用于证明设备使用者身份的证书…

作者头像 李华
网站建设 2026/4/23 9:45:36

职业发展规划:AI给出成长路径

职业发展规划&#xff1a;用 AI 构建你的成长路径引擎 在一家快速发展的科技公司里&#xff0c;新入职的工程师小李正为职业晋升感到迷茫。他打开内部知识库&#xff0c;输入问题&#xff1a;“我现在是中级前端&#xff0c;想三年内成为技术专家&#xff0c;该怎么做&#xff…

作者头像 李华
网站建设 2026/4/23 9:45:17

22、Windows Phone 媒体管理应用开发指南

Windows Phone 媒体管理应用开发指南 随机播放歌曲功能 在开发音乐播放应用时,随机播放功能能为用户带来更多的惊喜。以下是实现随机播放歌曲的代码示例: private Song DoShuffle() { App app = Application.Current as App; int count = library.Songs.Count; Random r…

作者头像 李华
网站建设 2026/4/23 9:45:28

稳定ip代理值得买吗?深度评测告诉你答案

对于许多从事数据采集、市场监测、跨境访问等业务的企业和开发者来说&#xff0c;代理IP几乎是刚需。然而&#xff0c;很多人都经历过IP频繁掉线、连接失败率高、访问速度慢等问题。此时&#xff0c;“稳定IP代理”成为了更优解。但稳定IP代理到底值不值得投资&#xff1f;是否…

作者头像 李华
网站建设 2026/4/23 9:45:13

基于Hadoop的宁波旅游推荐周边商城实现与设计(毕设源码+文档)

背景 本课题聚焦游客宁波旅游个性化、便捷化的需求&#xff0c;设计开发基于Hadoop的宁波旅游推荐周边商城系统。项目以Hadoop生态体系为核心大数据处理架构&#xff0c;结合SpringBoot实现后端服务支撑&#xff0c;搭配MySQL与HBase实现用户基础信息、宁波旅游资源数据&#x…

作者头像 李华
网站建设 2026/4/23 9:58:30

基于或非门的逻辑综合:组合电路设计通俗解释

从一个门开始&#xff1a;用或非门“搭”出整个数字世界你有没有想过&#xff0c;一个看似简单的逻辑门&#xff0c;真的能撑起整个数字系统&#xff1f;在现代芯片内部&#xff0c;成千上万的晶体管协同工作&#xff0c;完成着加法、判断、存储等复杂任务。而这些功能的起点&a…

作者头像 李华