Spring Boot 中的 Native SQL 是什么, 如何使用

news2025/1/21 11:29:24

Spring Boot 中的 Native SQL 是什么, 如何使用

在 Spring Boot 中,我们通常使用 ORM 框架(例如 Hibernate 或 MyBatis)来操作数据库。但是,有时候我们需要执行一些自定义的 SQL 查询或更新语句,这时候就需要使用 Spring Boot 中的 Native SQL。

在本文中,我们将介绍 Spring Boot 中的 Native SQL 是什么,以及如何使用它来执行自定义的 SQL 查询或更新语句。

什么是 Native SQL

Native SQL 是指直接使用 SQL 语句来操作数据库,而不是使用 ORM 框架提供的 API。使用 Native SQL 可以提高查询效率,并且可以执行一些复杂的 SQL 查询或更新语句。

在 Spring Boot 中,我们可以使用 JdbcTemplate 或 NamedParameterJdbcTemplate 类来执行 Native SQL。

使用 JdbcTemplate 执行 Native SQL

JdbcTemplate 是 Spring Boot 提供的一个用于执行 SQL 语句的工具类。它可以执行任何 SQL 语句,并且支持自定义的 RowMapper 来将查询结果映射到 Java 对象。

步骤一:添加依赖

首先,你需要在你的项目中添加 Spring Boot 的 JdbcTemplate 依赖。在 Maven 中,你可以添加以下依赖:

<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-jdbc</artifactId>
</dependency>

步骤二:创建 JdbcTemplate 实例

在你的代码中,你可以使用 Spring Boot 的自动配置功能来创建 JdbcTemplate 实例。例如:

@Autowired
JdbcTemplate jdbcTemplate;

在上面的代码中,我们使用 @Autowired 注解来注入 JdbcTemplate 实例。

步骤三:执行 SQL 语句

使用 JdbcTemplate 执行 SQL 语句非常简单。你可以使用 JdbcTemplate 的 query() 方法来执行查询语句,使用 update() 方法来执行更新语句。例如:

// 查询语句
List<MyObject> results = jdbcTemplate.query(
        "SELECT * FROM my_table WHERE id = ?",
        new Object[] { 123 },
        new RowMapper<MyObject>() {
            public MyObject mapRow(ResultSet rs, int rowNum) throws SQLException {
                MyObject obj = new MyObject();
                obj.setId(rs.getInt("id"));
                obj.setName(rs.getString("name"));
                return obj;
            }
        });

// 更新语句
int rowsUpdated = jdbcTemplate.update(
        "UPDATE my_table SET name = ? WHERE id = ?",
        "New Name", 123);

在上面的代码中,我们使用 JdbcTemplate 执行了一个查询语句和一个更新语句。在查询语句中,我们使用了一个自定义的 RowMapper 将查询结果映射到了一个自定义的 Java 对象中。

使用 NamedParameterJdbcTemplate 执行 Native SQL

NamedParameterJdbcTemplate 是 JdbcTemplate 的一个扩展,它支持使用命名参数来代替占位符。使用命名参数可以使 SQL 语句更加清晰易读,并且可以避免参数位置不匹配的问题。

步骤一:添加依赖

首先,你需要在你的项目中添加 Spring Boot 的 NamedParameterJdbcTemplate 依赖。在 Maven 中,你可以添加以下依赖:

<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-jdbc</artifactId>
</dependency>

步骤二:创建 NamedParameterJdbcTemplate 实例

在你的代码中,你可以使用 Spring Boot 的自动配置功能来创建 NamedParameterJdbcTemplate 实例。例如:

@Autowired
NamedParameterJdbcTemplate jdbcTemplate;

在上面的代码中,我们使用 @Autowired 注解来注入 NamedParameterJdbcTemplate 实例。

步骤三:执行 SQL 语句

使用 NamedParameterJdbcTemplate 执行 SQL 语句也非常简单。你可以使用 NamedParameterJdbcTemplate 的 query() 方法来执行查询语句,使用 update() 方法来执行更新语句。例如:

// 查询语句
Map<String, Object> params = new HashMap<String, Object>();
params.put("id", 123);
List<MyObject> results = jdbcTemplate.query(
        "SELECT * FROM my_table WHERE id = :id",
        params,
        new RowMapper<MyObject>() {
            public MyObject mapRow(ResultSet rs, int rowNum) throws SQLException {
                MyObject obj = new MyObject();
                obj.setId(rs.getInt("id"));
                obj.setName(rs.getString("name"));
                return obj;
            }
        });

// 更新语句
Map<String, Object> params = new HashMap<String, Object>();
params.put("name", "New Name");
params.put("id", 123);
int rowsUpdated = jdbcTemplate.update(
        "UPDATE my_table SET name = :name WHERE id = :id",
        params);

在上面的代码中,我们使用 NamedParameterJdbcTemplate 执行了一个查询语句和一个更新语句。在查询语句中,我们使用了命名参数来代替占位符,使 SQL 语句更加清晰易读。在更新语句中,我们同样使用了命名参数来代替占位符。

总结

在本文中,我们介绍了 Spring Boot 中的 Native SQL,以及如何使用 JdbcTemplate 和 NamedParameterJdbcTemplate 来执行自定义的 SQL 查询或更新语句。使用 Native SQL 可以提高查询效率,并且可以执行一些复杂的 SQL 查询或更新语句。同时,使用命名参数可以使 SQL 语句更加清晰易读,并且可以避免参数位置不匹配的问题。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/730874.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Matlab绘图系列教程-Matlab 34 种绘图函数示例(下)

Matlab绘图系列教程&#xff1a;揭秘高质量科学图表的绘制与优化 文章目录 Matlab绘图系列教程&#xff1a;揭秘高质量科学图表的绘制与优化第一部分&#xff1a;入门指南1.1 简介关于本教程的目的与范围Matlab绘图在科学研究中的重要性 1.2 准备工作安装Matlab及其工具箱 1.3 …

8、添加PolylineCollection线

本节演示添加线要素&#xff0c;使用第四节单击事件的例子&#xff0c;修改点击事件创建线要素。 1、重新修改地图默认位置 double r glm::radians(-45.0); Cesium::HeadingPitchRoll *orientation new Cesium::HeadingPitchRoll(0.0, r, 0.0); glm::dvec3 initialPosition…

map和set的封装

目录 封装逻辑 用红黑树封装set和map 红黑树的定义改变 迭代器 红黑树的迭代器 set的迭代器 map重载[]操作的实现 比较关键——得到 key的类型K 封装逻辑 用红黑树封装set和map map和set用红黑树来实现的&#xff1b;红黑树的前三个模板参数分别表示&#xff1a;得到key的…

C语言---程序环境和预处理(底层原理万字详解)

文章目录 前言&#x1f31f;一、程序的翻译环境和执行环境&#x1f31f;二、详解编译链接&#x1f30f;2.1命令&#x1f30f;2.2 板书详解&#x1f30f;2.3运行环境 &#x1f31f;三、预处理详解&#x1f30f;3.1预定义符号&#x1f30f;3.2 #define&#x1f4ab;3.2.1 #define…

第三章 SSD存储介质:闪存

3.1 闪存物理结构 闪存芯片从小到大依此是由&#xff1a;cell&#xff08;单元&#xff09;、page&#xff08;页&#xff09;、block&#xff08;块&#xff09;、plane&#xff08;平面&#xff09;、die&#xff08;核心&#xff09;、NAND flash&#xff08;闪存芯片&#…

【动手学习深度学习--逐行代码解析合集】10Dropout暂退法

【动手学习深度学习】逐行代码解析合集 10Dropout暂退法 视频链接&#xff1a;动手学习深度学习–Dropout暂退法 课程主页&#xff1a;https://courses.d2l.ai/zh-v2/ 教材&#xff1a;https://zh-v2.d2l.ai/ 1、暂退法原理 2、从零开始实现暂退法 import torch from torch i…

微服务网关技术选型:Zuul2、Gateway、OpenResty、Kong

1、简介 当使用单体应用程序架构时&#xff0c;客户端&#xff08;Web 或移动端&#xff09;通过向后端应用程序发起一次 REST 调用来获取数据。负载均衡器将请求路由给 N 个相同的应用程序实例中的一个。然后应用程序会查询各种数据库表&#xff0c;并将响应返回给客户端。微…

missing-semester————1

文章目录 shell概述echoshell如何知道去哪寻找date或echo呢&#xff1f;$PATHlsman流根用户 shell概述 root1test:~$ $表示身份不是root用户 ~表示当前所在位置是"home" root1test:~$ date Sat Jul 8 02:57:44 UTC 2023输入命令&#xff0c;会被shell解析 上述执行…

静态路由配置——Cisco Packet Tracer

这里放一个用Packet Tracer 8.0实现的配置好的静态路由文件&#xff0c;配置如下 下载链接如下&#xff1a; https://wwix.lanzoue.com/ifp5T11ksnla

内嵌tomcat报错

严重: Unable to process Jar entry [module-info.class] from Jar [jar:file:/D:/javaTools/apache-maven-bin/apache-maven-3.6.1/maven-repo/com/fasterxml/jackson/core/jackson-databind/2.10.5/jackson-databind-2.10.5.jar!/] for annotations org.apache.tomcat.util.b…

NI采集卡USB-6361多通道模拟输入采集报错解决方案

文章目录 前言一、现有例程1、前面板2、程序框图 二、采集测试1、单通道采集2、多通道采集①、错误的做法②、正确的做法1&#xff09;前面板2&#xff09;程序框图3&#xff09;运行测试 总结 前言 折腾一块 USB-6361 采集卡很久了&#xff0c;之前都是单通道采集模拟信号&am…

云原生(第六篇)k8s-kubeadmin部署

master&#xff08;2C/4G&#xff0c;cpu核心数要求大于2&#xff09; 192.168.169.10 docker、kubeadm、kubelet、kubectl、flannel node01&#xff08;2C/2G&#xff09; 192.168.169.30 docker、kubeadm、kubelet、kubect…

汇总:FlatLaf-intellij-themes皮肤效果一览

关于主题包&#xff1a; FlatLaf 是一个跨平台的 Java Swing 外观库&#xff0c;提供现代化的平面化用户界面。 导包 <dependency><groupId>com.formdev</groupId><artifactId>flatlaf</artifactId><version>3.1.1</version><sco…

机器学习28:《推荐系统-I》概述

在互联网领域&#xff0c;推荐系统&#xff08;Recommendation Systems&#xff09;的应用非常广泛。在音视频方面&#xff0c;如抖音、快手、哔哩等&#xff1b;在电商平台方面&#xff0c;如京东、淘宝、拼多多等。推荐有助于帮助用户快速发现潜在感兴趣的内容&#xff08;音…

RS485或RS232转ETHERCAT连接安川ethercat总线伺服

最近&#xff0c;生产管理设备中经常会遇到两种协议不相同的情况&#xff0c;这严重阻碍了设备之间的通讯&#xff0c;串口设备的数据不能直接传输给ETHERCAT。这可怎么办呢&#xff1f; 别担心&#xff0c;远创智控YC-ECT-RS485/232来了&#xff01;这是一款自主研发的ETHER…

使用vue ui创建vue项目失败原因

每个人的失败原因都不相同&#xff0c;因为下载NodeJS文件时&#xff0c;默认下载到c盘中&#xff0c;我改变盘符到了D盘&#xff0c;因此要删除c盘中隐藏的文件&#xff0c;注意是c盘中的.npmrc文件。具体位置如下&#xff1a; 点击查看显示隐藏文件才能看到该文件 最后创建项…

磁性材料在使用时需要注意什么

为了不引起人身损伤及磁体性能不良&#xff0c;请遵循以下注意事项&#xff1a; 1、 磁体在使用过程中应确保工作场所干净&#xff0c;否则容易吸附铁屑等磁性小颗粒影响使用。 2、 磁体在充磁时&#xff0c;磁体必须固定&#xff0c;且充磁场必须大于磁体材料矫顽力的2.5倍&…

CEC2023动态多目标优化算法:基于自适应启动策略的混合交叉动态约束多目标优化算法(MC-DCMOEA)求解CEC2023(提供MATLAB代码)

一、动态多目标优化问题 1.1问题定义 1.2 动态支配关系定义 二、 基于自适应启动策略的混合交叉动态多目标优化算法 基于自适应启动策略的混合交叉动态多目标优化算法&#xff08;Mixture Crossover Dynamic Constrained Multi-objective Evolutionary Algorithm Based on Se…

【ElasticSearch】JavaRestClient实现文档查询、排序、分页、高亮

文章目录 1、入门案例2、全文检索3、精确查询4、复合查询-boolean query5、排序和分页6、高亮 1、入门案例 先初始化JavaRestClient对象&#xff1a; SpringBootTest public class HotelSearchTest {private RestHighLevelClient client;Testvoid testInit() {System.out.pri…

uniapp如何给空包进行签名操作

这里给大家分享我在网上总结出来的一些知识&#xff0c;希望对大家有所帮助 首先安装sdk https://www.oracle.com/java/technologies/downloads/ 正常下一步即可~安装完毕后&#xff0c;进入在sdk根目录执行cmd C:\Program Files\Java\jdk-18.0.1.1\bin生成keystore 例&#xf…