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

孙卫琴的《精通JPA与Hibernate》的读书笔记: 用JPQL批量处理数据

JPA的JPQL(JPA Query Language,JPA查询语言)不仅可以检索数据,还可以用于进行批量更新、删除和插入数据。批量操作实际上直接在数据库中完成,所处理的数据不会被保存在Session的持久化缓存中,因此不会占用内存空间。

Query.executeUpdate()方法和JDBC API中的PreparedStatement.executeUpdate()很相似,前者执行用于更新、删除和插入的JPQL语句,而后者执行用于更新、删除和插入的SQL语句。

1.批量更新数据

以下程序代码演示通过JPQL来批量更新Customer对象:

tx = entityManager.getTransaction();
tx.begin();

String jpqlUpdate ="update Customer c set c.name = :newName"
                  +" where c.name = :oldName";
int updatedEntities = entityManager.createQuery( jpqlUpdate )
        .setParameter( "newName", "Mike" )
        .setParameter( "oldName", "Tom" )
        .executeUpdate();

tx.commit();
entityManager.close();

以上程序代码向数据库发送的SQL语句为:

update CUSTOMERS set NAME="Mike" where NAME="Tom"

除了使用JPQL,还可以使用HQL(Hibernate Query Language,Hibernate查询语言)以及Hibernate API来进行批量更新。HQL语言和JPQL语言的语法几乎是相同的:

Session session = sessionFactory.openSession();
Transaction tx = session.beginTransaction();

String hqlUpdate ="update Customer c set c.name = :newName"
                  +" where c.name = :oldName";
int updatedEntities = session.createQuery( hqlUpdate )
        .setParameter( "newName", "Mike" )
        .setParameter( "oldName", "Tom" )
        .executeUpdate();

tx.commit();
session.close();

2.批量删除数据

EntityManager的remove()方法一次只能删除一个对象,不适合进行批量删除操作。以下程序代码演示通过JPQL来批量删除Customer对象:

tx = entityManager.getTransaction();
tx.begin();

String jpqlDelete = "delete Customer c where c.name = :oldName";
int deletedEntities = entityManager.createQuery( jpqlDelete )
        .setParameter( "oldName", "Tom" )
        .executeUpdate();

tx.commit();
entityManager.close();

以上程序代码向数据库提交的SQL语句为:

delete from CUSTOMERS where NAME="Tom"

3.批量插入数据
插入数据的JPQL语法为:

insert into EntityName properties_list select_statement

以上EntityName表示持久化类的名字,properties_list表示持久化类的属性列表,select_statement表示子查询语句。

JPQL只支持insert into … select … 形式的插入语句,而不支持“insert into … values … ”形式的插入语句。

下面举例说明如何通过JPQL来批量插入数据。假定有DelinquentAccount类和Customer类,它们都用@Entity注解等进行了对象-关系映射。它们都有id和name属性,与这两个类对应的表分别为DELINQUENT_ACCOUNTS和CUSTOMERS表。以下代码能够把CUSTOMERS表中的数据复制到DELINQUENT_ACCOUNTS表中:

tx = entityManager.getTransaction();
tx.begin();

String jpqlInsert = "insert into DelinquentAccount (id, name) "
        +"select c.id, c.name from Customer c where c.id>1";

int createdEntities = entityManager.createQuery( jpqlInsert )
                             .executeUpdate();

tx.commit();
entityManager.close();	

以上程序代码向数据库提交的SQL语句为:

insert into DELINQUENT_ACCOUNTS(ID,NAME) 
select ID,NAME from CUSTOMERS where ID>1

在这里插入图片描述

相关文章:

  • linux常用小知识点记录
  • 91.(leaflet之家)leaflet态势标绘-进攻方向绘制
  • Spring Boot + Netty + WebSocket 实现消息推送
  • 【毕业设计】Yolov安全帽佩戴检测 危险区域进入检测 - 深度学习 opencv
  • 18. JavaScript 中如何进行隐式类型转换?
  • 【面试题】2022前端面试真题
  • TIA博途V17中ProDiag功能的使用方法示例(二)可编辑的文本框
  • SSM学生健康防疫信息管理毕业设计-附源码041613
  • 使用node.js创建一个todo列表——node.js服务器搭建以及json读写
  • 如何通过经纬度坐标获取附近的地址信息?
  • LNMP+Redis
  • 记一次java组装elementPlus的TreeSelect树形菜单的数据结构
  • springboot基于web模式的师资管理系统的设计与实现毕业设计源码040928
  • 计算机复试面试题总结
  • 计算机二级--java篇
  • python3.6+scrapy+mysql 爬虫实战
  • __proto__ 和 prototype的关系
  • 【RocksDB】TransactionDB源码分析
  • 2017-08-04 前端日报
  • canvas 高仿 Apple Watch 表盘
  • Django 博客开发教程 8 - 博客文章详情页
  • Java 11 发布计划来了,已确定 3个 新特性!!
  • k8s 面向应用开发者的基础命令
  • Map集合、散列表、红黑树介绍
  • vue自定义指令实现v-tap插件
  • 从0到1:PostCSS 插件开发最佳实践
  • 对象引论
  • 二维平面内的碰撞检测【一】
  • 湖南卫视:中国白领因网络偷菜成当代最寂寞的人?
  • 全栈开发——Linux
  • 入门级的git使用指北
  • 一份游戏开发学习路线
  • ​Base64转换成图片,android studio build乱码,找不到okio.ByteString接腾讯人脸识别
  • #NOIP 2014#Day.2 T3 解方程
  • #每日一题合集#牛客JZ23-JZ33
  • (01)ORB-SLAM2源码无死角解析-(56) 闭环线程→计算Sim3:理论推导(1)求解s,t
  • (07)Hive——窗口函数详解
  • (4)(4.6) Triducer
  • (C语言)strcpy与strcpy详解,与模拟实现
  • (Redis使用系列) Springboot 使用redis实现接口Api限流 十
  • (Spark3.2.0)Spark SQL 初探: 使用大数据分析2000万KF数据
  • (SpringBoot)第七章:SpringBoot日志文件
  • (差分)胡桃爱原石
  • (附源码)spring boot基于小程序酒店疫情系统 毕业设计 091931
  • (附源码)基于SpringBoot和Vue的厨到家服务平台的设计与实现 毕业设计 063133
  • (附源码)计算机毕业设计高校学生选课系统
  • (十二)python网络爬虫(理论+实战)——实战:使用BeautfulSoup解析baidu热搜新闻数据
  • (四)图像的%2线性拉伸
  • (转) RFS+AutoItLibrary测试web对话框
  • .net core 实现redis分片_基于 Redis 的分布式任务调度框架 earth-frost
  • .NET Core 中插件式开发实现
  • .NET core 自定义过滤器 Filter 实现webapi RestFul 统一接口数据返回格式
  • .NET Framework与.NET Framework SDK有什么不同?
  • .net 获取url的方法
  • .Net8 Blazor 尝鲜