当前位置: 首页 > news >正文

【Spring 篇】JdbcTemplate:轻松驾驭数据库的魔法工具

在这里插入图片描述

欢迎来到数据库的奇妙世界,在这里,我们将一同揭开Spring框架中JdbcTemplate的神秘面纱。JdbcTemplate是Spring提供的一个简化数据库操作的工具,它为我们提供了一种轻松驾驭数据库的魔法。本篇博客将详细解释JdbcTemplate的基本使用,适合刚刚接触Spring的小白们,让你轻松驾驭数据库的魔法世界。

JdbcTemplate的魅力

在现代应用程序中,数据库是存储和检索数据的重要组成部分。然而,直接使用传统的JDBC(Java Database Connectivity)进行数据库操作会显得繁琐冗长,这时候JdbcTemplate就是一种救赎。JdbcTemplate是Spring框架对JDBC的封装,提供了更简单、更高效的数据库操作方式。

JdbcTemplate的基本用法

让我们从头开始,一步步探讨JdbcTemplate的基本用法。在Spring中使用JdbcTemplate需要先配置数据源(DataSource),这通常在Spring的配置文件中完成。以下是一个简单的配置示例:

<bean id="dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource"><property name="driverClassName" value="com.mysql.cj.jdbc.Driver"/><property name="url" value="jdbc:mysql://localhost:3306/mydatabase"/><property name="username" value="root"/><property name="password" value="password"/>
</bean><bean id="jdbcTemplate" class="org.springframework.jdbc.core.JdbcTemplate"><property name="dataSource" ref="dataSource"/>
</bean>

在这个例子中,我们配置了一个基本的DriverManagerDataSource数据源和一个对应的JdbcTemplate。你需要根据你的数据库信息修改urlusernamepassword属性。

查询操作

查询单个值

使用JdbcTemplate执行查询操作是非常简单的。首先,我们来看如何查询单个值,比如统计表中的记录数。以下是一个查询总记录数的例子:

public class UserDao {private JdbcTemplate jdbcTemplate;// setter method for jdbcTemplatepublic int getTotalUsers() {String sql = "SELECT COUNT(*) FROM users";return jdbcTemplate.queryForObject(sql, Integer.class);}
}

在这个例子中,我们使用queryForObject方法执行SQL查询,指定了SQL语句和返回类型。Integer.class表示我们期望返回一个整数。

查询单行记录

如果我们想查询一行记录,可以使用RowMapper接口。以下是一个查询用户信息的例子:

public class UserDao {private JdbcTemplate jdbcTemplate;// setter method for jdbcTemplatepublic User getUserById(int userId) {String sql = "SELECT * FROM users WHERE id = ?";return jdbcTemplate.queryForObject(sql, new Object[]{userId}, new UserRowMapper());}private static class UserRowMapper implements RowMapper<User> {@Overridepublic User mapRow(ResultSet resultSet, int rowNum) throws SQLException {User user = new User();user.setId(resultSet.getInt("id"));user.setUsername(resultSet.getString("username"));user.setEmail(resultSet.getString("email"));return user;}}
}

在这个例子中,我们定义了一个UserRowMapper类实现了RowMapper<User>接口,用于映射查询结果到User对象。在getUserById方法中,我们使用queryForObject方法执行SQL查询,并传递了UserRowMapper作为映射器。

查询多行记录

如果我们想查询多行记录,可以使用query方法。以下是一个查询所有用户的例子:

public class UserDao {private JdbcTemplate jdbcTemplate;// setter method for jdbcTemplatepublic List<User> getAllUsers() {String sql = "SELECT * FROM users";return jdbcTemplate.query(sql, new UserRowMapper());}
}

在这个例子中,我们直接调用query方法,传递了SQL语句和UserRowMapper映射器。

更新操作

除了查询,JdbcTemplate还提供了便捷的更新操作。以下是一个更新用户信息的例子:

public class UserDao {private JdbcTemplate jdbcTemplate;// setter method for jdbcTemplatepublic void updateUser(User user) {String sql = "UPDATE users SET username = ?, email = ? WHERE id = ?";jdbcTemplate.update(sql, user.getUsername(), user.getEmail(), user.getId());}
}

在这个例子中,我们使用update方法执行SQL更新操作,传递了SQL语句和更新所需的参数。update方法可以用于执行任何更新操作,包括插入、更新和删除。

插入操作

接下来,我们看一下如何使用JdbcTemplate执行插入操作。以下是一个插入新用户的例子:

public class UserDao {private JdbcTemplate jdbcTemplate;// setter method for jdbcTemplatepublic void addUser(User user) {String sql = "INSERT INTO users (username, email) VALUES (?, ?)";jdbcTemplate.update(sql, user.getUsername(), user.getEmail());}
}

在这个例子中,我们同样使用update方法执行SQL插入操作,传递了SQL语句和插入所需的参数。

删除操作

最后,让我们看一下如何使用JdbcTemplate执行删除操作。以下是一个删除用户的例子:

public class UserDao {private JdbcTemplate jdbcTemplate;// setter method for jdbcTemplatepublic void deleteUser(int userId) {String sql = "DELETE FROM users WHERE id = ?";jdbcTemplate.update(sql, userId);}
}

同样,我们使用update方法执行SQL删除操作,传递了SQL语句和删除所需的参数。

JdbcTemplate的事务管理

在实际应用中,事务管理是数据库操作不可或缺的一部分。Spring的JdbcTemplate也提供了对事务的支持,让我们来看一下如何使用JdbcTemplate进行事务管理。

首先,我们需要配置事务管理器。以下是一个使用DataSourceTransactionManager的例子:

<bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager"><property name="dataSource" ref="dataSource"/>
</bean>

在这个例子中,我们配置了一个DataSourceTransactionManager并将数据源dataSource注入其中。

然后,在使用JdbcTemplate的类中,我们需要注入事务管理器并使用@Transactional注解标记需要进行事务管理的方法。以下是一个使用事务的例子:

import org.springframework.transaction.annotation.Transactional;public class UserService {private JdbcTemplate jdbcTemplate;// setter method for jdbcTemplate@Transactionalpublic void transferMoney(int fromUserId, int toUserId, double amount) {// 执行转账操作// ...}
}

在这个例子中,我们使用了@Transactional注解标记transferMoney方法,表明该方法需要进行事务管理。当这个方法被调用时,如果发生异常,事务将回滚,否则事务将提交。

JdbcTemplate的异常处理

在实际开发中,对于数据库操作,异常处理是非常重要的一部分。JdbcTemplate为我们提供了DataAccessException异常体系,用于捕获和处理数据库操作可能抛出的异常。

以下是一个简单的异常处理的例子:

public class UserDao {private JdbcTemplate jdbcTemplate;// setter method for jdbcTemplatepublic void addUser(User user) {try {String sql = "INSERT INTO users (username, email) VALUES (?, ?)";jdbcTemplate.update(sql, user.getUsername(), user.getEmail());} catch (DataAccessException e) {// 处理数据库操作异常System.out.println("Error occurred while adding user: " + e.getMessage());}}
}

在这个例子中,我们使用了try-catch块捕获可能发生的DataAccessException,并在捕获到异常时进行处理。

JdbcTemplate的批处理操作

有时候我们需要执行批处理操作,JdbcTemplate也为我们提供了支持。以下是一个批处理插入的例子:

public class UserDao {private JdbcTemplate jdbcTemplate;// setter method for jdbcTemplatepublic void addUsers(List<User> users) {String sql = "INSERT INTO users (username, email) VALUES (?, ?)";jdbcTemplate.batchUpdate(sql, new BatchPreparedStatementSetter() {@Overridepublic void setValues(PreparedStatement preparedStatement, int i) throws SQLException {User user = users.get(i);preparedStatement.setString(1, user.getUsername());preparedStatement.setString(2, user.getEmail());}@Overridepublic int getBatchSize() {return users.size();}});}
}

在这个例子中,我们使用了batchUpdate方法执行批处理插入操作。通过实现BatchPreparedStatementSetter接口,我们可以设置每个批处理操作的参数,并通过getBatchSize方法指定批处理的大小。

JdbcTemplate的封装

为了使数据库操作更加便捷,我们通常会将JdbcTemplate进行封装。以下是一个简单的封装示例:

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.jdbc.core.JdbcTemplate;
import org.springframework.stereotype.Repository;import java.util.List;@Repository
public class UserDao {private final JdbcTemplate jdbcTemplate;@Autowiredpublic UserDao(JdbcTemplate jdbcTemplate) {this.jdbcTemplate = jdbcTemplate;}public int getTotalUsers() {String sql = "SELECT COUNT(*) FROM users";return jdbcTemplate.queryForObject(sql, Integer.class);}// 其他数据库操作方法...
}

在这个例子中,我们使用了@Repository注解将UserDao标记为一个持久层组件,同时通过构造函数注入了JdbcTemplate。这样,我们在UserDao中就可以直接使用jdbcTemplate进行数据库操作。

结语

JdbcTemplate是Spring框架中用于简化数据库操作的神奇工具,它为我们提供了一种轻松驾驭数据库的方式。通过本文的详细讲解,相信你已经对JdbcTemplate的基本使用有了清晰的了解。在数据库的奇妙世界中,JdbcTemplate为我们提供了强大的魔法,让我们能够轻松地进行各种数据库操作。

在你的编程旅程中,愿JdbcTemplate的魔法助你驾驭数据库的风云,轻松应对各种数据操作挑战。让我们一同在代码的世界中畅游,用JdbcTemplate为数据库的奇妙之旅添上灿烂的一笔吧!

作者信息

作者 : 繁依Fanyi
CSDN: https://techfanyi.blog.csdn.net
掘金:https://juejin.cn/user/4154386571867191

相关文章:

【Spring 篇】JdbcTemplate:轻松驾驭数据库的魔法工具

欢迎来到数据库的奇妙世界&#xff0c;在这里&#xff0c;我们将一同揭开Spring框架中JdbcTemplate的神秘面纱。JdbcTemplate是Spring提供的一个简化数据库操作的工具&#xff0c;它为我们提供了一种轻松驾驭数据库的魔法。本篇博客将详细解释JdbcTemplate的基本使用&#xff0…...

Web开发SpringBoot SpringMVC Spring的学习笔记(包含开发常用工具类)

开发框架学习笔记 一.Spring SpringMVC SpringBoot三者的联系SpringMVC工作原理 二.SpringBoot的学习2.1 注解2.1.1 SpringBoot的核心注解2.1.2 配置导入注解(简化Spring配置写XML的痛苦)Configuration和Bean(人为注册Spring 的 Bean)Import(补)ImportResource(补)AutowiredQua…...

微服务下的SpringSecurity认证端

从三板斧开始微服务下的SpringSecurity开始 一、引入组件包 <dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-oauth2</artifactId> </dependency> 二、创建适配器 AuthorizationServerConfig…...

苹果电脑菜单栏应用管理软件Bartender 4 mac软件特点

Bartender mac是一款可以帮助用户更好地管理和组织菜单栏图标的 macOS 软件。它允许用户隐藏和重新排列菜单栏图标&#xff0c;从而减少混乱和杂乱。 Bartender mac软件特点 菜单栏图标隐藏&#xff1a;Bartender 允许用户隐藏菜单栏图标&#xff0c;只在需要时显示。这样可以…...

笙默考试管理系统-MyExamTest----codemirror(65)

笙默考试管理系统-MyExamTest----codemirror&#xff08;65&#xff09; 目录 一、 笙默考试管理系统-MyExamTest----codemirror 二、 笙默考试管理系统-MyExamTest----codemirror 三、 笙默考试管理系统-MyExamTest----codemirror 四、 笙默考试管理系统-MyExamTest---…...

git在本地创建dev分支并和远程的dev分支关联起来

文章目录 git在本地创建dev分支并和远程的dev分支关联起来1. 使用git命令2. 使用idea2.1 先删除上面建的本地分支dev2.2 通过idea建dev分支并和远程dev分支关联 3. 查看本地分支和远程分支的关系 git在本地创建dev分支并和远程的dev分支关联起来 1. 使用git命令 git checkout…...

【C++】深入了解构造函数之初始化列表

目录 一、再谈构造函数 1、引入 1&#xff09;构造函数体赋值 2&#xff09;不同成员变量赋值 2、初始化列表 一、再谈构造函数 1、引入 1&#xff09;构造函数体赋值 在创建对象时&#xff0c;编译器通过调用构造函数&#xff0c;给对象中各个成员变量一个合适的初始值…...

差分--差分数组快速计算L到R值相加后的数组

目录 差分&#xff1a;思路代码&#xff1a; 原题链接 差分&#xff1a; 输入一个长度为 n 的整数序列。 接下来输入 m 个操作&#xff0c;每个操作包含三个整数 l,r,c &#xff0c;表示将序列中 [l,r] 之间的每个数加上 c 。 请你输出进行完所有操作后的序列。 输入格式 第…...

《NLP入门到精通》栏目导读(01/2)

一、说明 栏目《NLP入门到精通》本着从简到难得台阶式学习过度。将自然语言处理得知识贯穿过来。本栏目得前导栏目是《深度学习》、《pytorch实践》,因此,读者需要一定得深度学习基础,才能过度到此栏目内容。 二、博客建设理念 本博客基地,将建成人工智能领域的参考资料库;…...

three.js实现电子围栏效果(纹理贴图)

three.js实现电子围栏效果&#xff08;纹理贴图&#xff09; 实现步骤 围栏的坐标坐标转换为几何体顶点&#xff0c;uv顶点坐标加载贴图&#xff0c;移动 图例 代码 <template><div class"app"><div ref"canvesRef" class"canvas-…...

DHSP和DNS

一、服务程序 1.1DHCP定义 DHCP&#xff08;动态主机配置协议&#xff09;是一个局域网的网络协议。指的是由服务器控制一段IP地址范围&#xff0c;客户机登录服务器时就可以自动获得服务器分配的IP地址和子网掩码。默认情况下&#xff0c;DHCP作为Windows Server的一个服务组…...

Python冒号的解释

1. “没什么首次没有为第二个&#xff0c;跳了三个”。它得到的切片序列的每一个第三个项目。 扩展片是你想要的。新在Python 2.3 2. Python的序列切片地址可以写成[开始&#xff1a;结束&#xff1a;一步]和任何启动&#xff0c;停止或结束可以被丢弃。a[::3]是每第三个序列。…...

uniapp微信小程序投票系统实战 (SpringBoot2+vue3.2+element plus ) -后端鉴权拦截器实现

锋哥原创的uniapp微信小程序投票系统实战&#xff1a; uniapp微信小程序投票系统实战课程 (SpringBoot2vue3.2element plus ) ( 火爆连载更新中... )_哔哩哔哩_bilibiliuniapp微信小程序投票系统实战课程 (SpringBoot2vue3.2element plus ) ( 火爆连载更新中... )共计21条视频…...

固乔快递查询助手:批量、快速、全面的快递信息查询软件

在快递行业飞速发展的今天&#xff0c;如何高效、准确地掌握快递信息成为了很多人的需求。而固乔快递查询助手正是解决这一难题的利器。 固乔快递查询助手是一款专注于快递信息查询的软件&#xff0c;支持多家主流快递公司查询。用户只需输入单号&#xff0c;即可快速查询到实时…...

C#,归并排序算法(Merge Sort Algorithm)的源代码及数据可视化

归并排序 归并算法采用非常经典的分治策略&#xff0c;每次把序列分成n/2的长度&#xff0c;将问题分解成小问题&#xff0c;由复杂变简单。 因为使用了递归算法&#xff0c;不能用于大数据的排序。 核心代码&#xff1a; using System; using System.Text; using System.Co…...

Linux的网络服务DHCP

一.了解DHCP服务 1.1 DHCP定义 DHCP&#xff08;动态主机配置协议&#xff09;是一个局域网的网络协议。指的是由服务器控制一段IP地址范围&#xff0c;客户机登录服务器时就可以自动获得服务器分配的IP地址和子网掩码。默认情况下&#xff0c;DHCP作为Windows Server的一个服…...

【小沐学CAD】开源Assimp库导入三维模型(C++、Python)

文章目录 1、简介2、下载编译3、代码测试3.1 C3.2 pyassimp&#xff08;Python&#xff09; 结语 1、简介 https://github.com/assimp/assimp Open Asset Import Library 是一个库&#xff0c;用于将各种 3D 文件格式加载为共享的内存格式。它支持 40 多种用于导入的文件格式和…...

RT-Thread:SPI万能驱动 SFUD 驱动Flash W25Q64,通过 STM32CubeMX 配置 STM32 SPI 驱动

关键词&#xff1a;SFUD,FLASH,W25Q64&#xff0c;W25Q128&#xff0c;STM32F407 说明&#xff1a;RT-Thread 系统 使用 SPI万能驱动 SFUD 驱动 Flash W25Q64&#xff0c;通过 STM32CubeMX 配置 STM32 SPI 驱动。 提示&#xff1a;SFUD添加后的存储位置 1.打开RT-Thread Sett…...

Python学习笔记-使用Anaconda+VSCode配置开发环境

文章目录 概述一、安装Anaconda1.1 下载软件1.2 安装anaconda1.3 配置环境 二、配置虚拟环境2.1 使用conda创建一个新的虚拟环境2.1.1 使用search指令查看支持的python的版本&#xff1a;2.1.2 使用create创建指定版本的虚拟环境&#xff1a;2.1.3 使用env list查看虚拟环境列表…...

RabbitMQ的关键概念解析

RabbitMQ 是一个广泛使用的开源消息代理&#xff0c;它允许应用程序通过复杂的路由和存储机制来交换数据。理解 RabbitMQ 的核心概念对于有效地使用它至关重要。以下是 RabbitMQ 的一些关键概念及其工作流程&#xff1a; 关键概念 生产者&#xff08;Producer&#xff09; 生产…...

谷歌浏览器插件

项目中有时候会用到插件 sync-cookie-extension1.0.0&#xff1a;开发环境同步测试 cookie 至 localhost&#xff0c;便于本地请求服务携带 cookie 参考地址&#xff1a;https://juejin.cn/post/7139354571712757767 里面有源码下载下来&#xff0c;加在到扩展即可使用FeHelp…...

【第二十一章 SDIO接口(SDIO)】

第二十一章 SDIO接口 目录 第二十一章 SDIO接口(SDIO) 1 SDIO 主要功能 2 SDIO 总线拓扑 3 SDIO 功能描述 3.1 SDIO 适配器 3.2 SDIOAHB 接口 4 卡功能描述 4.1 卡识别模式 4.2 卡复位 4.3 操作电压范围确认 4.4 卡识别过程 4.5 写数据块 4.6 读数据块 4.7 数据流…...

Cinnamon修改面板小工具图标

Cinnamon开始菜单-CSDN博客 设置模块都是做好的&#xff0c;比GNOME简单得多&#xff01; 在 applet.js 里增加 const Settings imports.ui.settings;this.settings new Settings.AppletSettings(this, HTYMenusonichy, instance_id); this.settings.bind(menu-icon, menu…...

C++ Visual Studio 2017厂商给的源码没有.sln文件 易兆微芯片下载工具加开机动画下载。

1.先用Visual Studio 2017打开Yichip YC31xx loader.vcxproj&#xff0c;再用Visual Studio 2022打开。再保侟就有.sln文件了。 易兆微芯片下载工具加开机动画下载 ExtraDownloadFile1Info.\logo.bin|0|0|10D2000|0 MFC应用兼容CMD 在BOOL CYichipYC31xxloaderDlg::OnIni…...

R语言速释制剂QBD解决方案之三

本文是《Quality by Design for ANDAs: An Example for Immediate-Release Dosage Forms》第一个处方的R语言解决方案。 第一个处方研究评估原料药粒径分布、MCC/Lactose比例、崩解剂用量对制剂CQAs的影响。 第二处方研究用于理解颗粒外加硬脂酸镁和滑石粉对片剂质量和可生产…...

算法:模拟

1.替换所有的问号 1576. 替换所有的问号 - 力扣&#xff08;LeetCode&#xff09; ​遍历字符串​&#xff1a;通过外层循环逐一检查每个字符。​遇到 ? 时处理​&#xff1a; 内层循环遍历小写字母&#xff08;a 到 z&#xff09;。对每个字母检查是否满足&#xff1a; ​与…...

【Linux】Linux 系统默认的目录及作用说明

博主介绍&#xff1a;✌全网粉丝23W&#xff0c;CSDN博客专家、Java领域优质创作者&#xff0c;掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java技术领域✌ 技术范围&#xff1a;SpringBoot、SpringCloud、Vue、SSM、HTML、Nodejs、Python、MySQL、PostgreSQL、大数据、物…...

Neko虚拟浏览器远程协作方案:Docker+内网穿透技术部署实践

前言&#xff1a;本文将向开发者介绍一款创新性协作工具——Neko虚拟浏览器。在数字化协作场景中&#xff0c;跨地域的团队常需面对实时共享屏幕、协同编辑文档等需求。通过本指南&#xff0c;你将掌握在Ubuntu系统中使用容器化技术部署该工具的具体方案&#xff0c;并结合内网…...

实战设计模式之模板方法模式

概述 模板方法模式定义了一个操作中的算法骨架&#xff0c;并将某些步骤延迟到子类中实现。模板方法使得子类可以在不改变算法结构的前提下&#xff0c;重新定义算法中的某些步骤。简单来说&#xff0c;就是在一个方法中定义了要执行的步骤顺序或算法框架&#xff0c;但允许子类…...

怎么开发一个网络协议模块(C语言框架)之(六) ——通用对象池总结(核心)

+---------------------------+ | operEntryTbl[] | ← 操作对象池 (对象数组) +---------------------------+ | 0 | 1 | 2 | ... | N-1 | +---------------------------+↓ 初始化时全部加入 +------------------------+ +-------------------------+ | …...