Spring Data Jpa 使用EntityManager执行SQL操作数据

本文主要是介绍Spring Data Jpa 使用EntityManager执行SQL操作数据,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

使用EntityManager执行原生SQL语句可以通过createNativeQuery方法实现。以下是一个简单的例子,演示如何使用EntityManager执行SQL语句进行数据库操作。

import javax.persistence.EntityManager;
import javax.persistence.PersistenceContext;
import javax.transaction.Transactional;
import java.util.List;@Transactional
public class MyService {@PersistenceContext//@Autowiredprivate EntityManager entityManager;// 插入数据public void insertData(String name, int age) {String sql = "INSERT INTO person (name, age) VALUES (?, ?)";entityManager.createNativeQuery(sql).setParameter(1, name).setParameter(2, age).executeUpdate();}// 查询数据public List<Object[]> getAllPersons() {String sql = "SELECT * FROM person";return entityManager.createNativeQuery(sql).getResultList();}// 带查询条件的查询。my_entity_table是表名,status是表字段名public List<MyEntity> findEntitiesWithStatus(String status) {String sql = "SELECT * FROM my_entity_table WHERE status = :status";return entityManager.createNativeQuery(sql, MyEntity.class).setParameter("status", status).getResultList();}// 更新数据public void updatePersonAge(String name, int newAge) {String sql = "UPDATE person SET age = ? WHERE name = ?";entityManager.createNativeQuery(sql).setParameter(1, newAge).setParameter(2, name).executeUpdate();}// 删除数据public void deletePerson(String name) {String sql = "DELETE FROM person WHERE name = ?";entityManager.createNativeQuery(sql).setParameter(1, name).executeUpdate();}
}

@PersistenceContext和@Autowired都是用于依赖注入的注解,但它们的使用场景和依赖关系略有不同。
@PersistenceContext:
专门用于注入EntityManager,这是Java Persistence API (JPA) 的一部分,用于与持久性上下文(数据库)进行交互。
更为特定于JPA,通常在JPA或Hibernate等ORM框架的应用中使用。

在这个例子中,我们使用了createNativeQuery方法来创建原生SQL查询,并通过setParameter方法设置参数。executeUpdate方法用于执行更新、插入和删除操作,而getResultList方法用于执行查询操作。

请注意,这里使用的是原生SQL,因此表名和字段名需要与数据库中的实际情况一致。在实际开发中,为了防止SQL注入等安全问题,最好使用参数化查询,就像上面的例子一样使用setParameter方法。

此外,建议在Spring Boot应用程序中使用Spring Data JPA,因为它提供了更高级、更安全的查询方式,并且更符合Spring的习惯。只有在需要执行复杂的原生SQL操作时,才应考虑使用EntityManager执行原生SQL。

这篇关于Spring Data Jpa 使用EntityManager执行SQL操作数据的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/576444

相关文章

使用DeepSeek API 结合VSCode提升开发效率

《使用DeepSeekAPI结合VSCode提升开发效率》:本文主要介绍DeepSeekAPI与VisualStudioCode(VSCode)结合使用,以提升软件开发效率,具有一定的参考价值... 目录引言准备工作安装必要的 VSCode 扩展配置 DeepSeek API1. 创建 API 请求文件2.

使用TomCat,service输出台出现乱码的解决

《使用TomCat,service输出台出现乱码的解决》本文介绍了解决Tomcat服务输出台中文乱码问题的两种方法,第一种方法是修改`logging.properties`文件中的`prefix`和`... 目录使用TomCat,service输出台出现乱码问题1解决方案问题2解决方案总结使用TomCat,

IDEA运行spring项目时,控制台未出现的解决方案

《IDEA运行spring项目时,控制台未出现的解决方案》文章总结了在使用IDEA运行代码时,控制台未出现的问题和解决方案,问题可能是由于点击图标或重启IDEA后控制台仍未显示,解决方案提供了解决方法... 目录问题分析解决方案总结问题js使用IDEA,点击运行按钮,运行结束,但控制台未出现http://

解决Spring运行时报错:Consider defining a bean of type ‘xxx.xxx.xxx.Xxx‘ in your configuration

《解决Spring运行时报错:Considerdefiningabeanoftype‘xxx.xxx.xxx.Xxx‘inyourconfiguration》该文章主要讲述了在使用S... 目录问题分析解决方案总结问题Description:Parameter 0 of constructor in x

解决IDEA使用springBoot创建项目,lombok标注实体类后编译无报错,但是运行时报错问题

《解决IDEA使用springBoot创建项目,lombok标注实体类后编译无报错,但是运行时报错问题》文章详细描述了在使用lombok的@Data注解标注实体类时遇到编译无误但运行时报错的问题,分析... 目录问题分析问题解决方案步骤一步骤二步骤三总结问题使用lombok注解@Data标注实体类,编译时

JSON字符串转成java的Map对象详细步骤

《JSON字符串转成java的Map对象详细步骤》:本文主要介绍如何将JSON字符串转换为Java对象的步骤,包括定义Element类、使用Jackson库解析JSON和添加依赖,文中通过代码介绍... 目录步骤 1: 定义 Element 类步骤 2: 使用 Jackson 库解析 jsON步骤 3: 添

Java中注解与元数据示例详解

《Java中注解与元数据示例详解》Java注解和元数据是编程中重要的概念,用于描述程序元素的属性和用途,:本文主要介绍Java中注解与元数据的相关资料,文中通过代码介绍的非常详细,需要的朋友可以参... 目录一、引言二、元数据的概念2.1 定义2.2 作用三、Java 注解的基础3.1 注解的定义3.2 内

将sqlserver数据迁移到mysql的详细步骤记录

《将sqlserver数据迁移到mysql的详细步骤记录》:本文主要介绍将SQLServer数据迁移到MySQL的步骤,包括导出数据、转换数据格式和导入数据,通过示例和工具说明,帮助大家顺利完成... 目录前言一、导出SQL Server 数据二、转换数据格式为mysql兼容格式三、导入数据到MySQL数据

Java中使用Java Mail实现邮件服务功能示例

《Java中使用JavaMail实现邮件服务功能示例》:本文主要介绍Java中使用JavaMail实现邮件服务功能的相关资料,文章还提供了一个发送邮件的示例代码,包括创建参数类、邮件类和执行结... 目录前言一、历史背景二编程、pom依赖三、API说明(一)Session (会话)(二)Message编程客

Java中List转Map的几种具体实现方式和特点

《Java中List转Map的几种具体实现方式和特点》:本文主要介绍几种常用的List转Map的方式,包括使用for循环遍历、Java8StreamAPI、ApacheCommonsCollect... 目录前言1、使用for循环遍历:2、Java8 Stream API:3、Apache Commons