>>分享JPA、Hibernate、Mybatis对象持久化技术,对《精通JPA与Hibernate:Java对象持久化详解》提供技术支持 书籍支持  卫琴直播  品书摘要  在线测试  资源下载  联系我们
发表一个新主题 开启一个新投票 回复文章 您是本文章第 14983 个阅读者 刷新本主题
 * 贴子主题:  孙卫琴的《精通JPA与Hibernate》的读书笔记: 用JPQL批量处理数据 回复文章 点赞(0)  收藏  
作者:Jacky    发表时间:2021-05-05 05:43:43     消息  查看  搜索  好友  邮件  复制  引用

  
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

  点击在新窗口中浏览原图
CTRL+鼠标滚轮放大或缩小


程序猿的技术大观园:www.javathinker.net



[这个贴子最后由 flybird 在 2021-05-08 21:00:06 重新编辑]
  Java面向对象编程-->面向对象开发方法概述之UML语言(下)
  JavaWeb开发-->JSP中使用JavaBean(Ⅰ)
  JSP与Hibernate开发-->映射组成关系
  Java网络编程-->对象的序列化与反序列化
  精通Spring-->Vue组件开发基础
  Vue3开发-->CSS过渡和动画
  分布式事务浅析及简单实现
  孙卫琴的《精通JPA与Hibernate》的读书笔记:在程序中动态指定...
  孙卫琴的《精通JPA与Hibernate》的读书笔记:比较JPA的Entit...
  Spring JPA 使用注解方式进行事务管理
  用注解和XML描述对象-关系映射的区别,和优缺点
  Hibernate中通过FetchProfile的方式实现动态数据获取
  分析hibernate中table per class hierarchy映射方式容易出现...
  JPA @Convert注解的用法
  Hibernate的二级缓存
  Session的refresh()方法与事务隔离级别的关系
  好书推荐:《精通Hibernate:Java对象持久化技术详解》
  JPA EntityManager类的常用方法的作用
  JPQL与SQL的区别
  JP注解(标注)和Hibernate注解(标注) 用法详解
  JPA API入门
  更多...
 IPIP: 已设置保密
树形列表:   
1页 0条记录 当前第1
发表一个新主题 开启一个新投票 回复文章


中文版权所有: JavaThinker技术网站 Copyright 2016-2026 沪ICP备16029593号-2
荟萃Java程序员智慧的结晶,分享交流Java前沿技术。  联系我们
如有技术文章涉及侵权,请与本站管理员联系。