如何解决Hibernate批量更新问题

技术如何解决Hibernate批量更新问题这篇文章主要介绍了如何解决Hibernate批量更新问题,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。对于Hib

本文主要介绍如何解决Hibernate的批量更新问题,具有一定的参考价值。有兴趣的朋友可以参考一下。希望大家看完这篇文章后有很多收获。让边肖带你去了解一下。

对于Hibernate的批量更新操作,Hibernate会找出符合要求的数据,然后进行更新操作。批量删除也是如此。首先找出符合条件的数据,然后删除。

这有两个主要缺点:

1.占用大量内存。

2.在处理海量数据时,执行update/delete语句是海量的,一条update/delete语句只能操作一个对象,所以应该可以想象,频繁操作数据库时性能会很低。

Hibernate3发布后,Hibernate的批量更新/删除操作引入了批量更新/删除。其原理是通过一条HQL语句完成批量更新/删除操作,这与JDBC的批量更新/删除操作非常相似。与Hibernate批量更新/删除相比,性能大幅提升。

transactiontx=session . BeginSession();StringHQL=” deleteSTUDENTquery query=session . createquery(HQL);int size=query . execute update();tx.commit();……控制台只输出一条删除语句hibernate: delete from t _ student。语句的执行较少,性能与JDBC几乎相同,是一种很好的提升性能的方法。当然,为了有更好的性能,作者建议使用JDBC进行批量更新和删除。方法和基本知识点与上面的批量插入方法2基本相同,在此不再赘述。

在这里,作者提供了另一种方法,即从数据库端考虑提高性能,从Hibernate程序端调用存储过程。存储过程在数据库端运行得更快。以批量更新为例,给出了参考代码。

首先,在数据库端建立一个名为batchUpdateStudent的存储过程:

transactiontx=session . BeginSession();connection conn=session . connection();string PD=”……{ callbatchUpdateStudent(?)}”;callablestatementcstt=conn . prepare call(PD);csmt . setint(1,20);//将年龄参数设置为20tx.com MIT();看看上面的代码,也是绕过Hibernate API,使用JDBC API调用存储过程,使用Hibernate的事务边界。存储过程无疑是提高批处理性能的好方法。它直接与数据库一起运行,在某种程度上将批处理的压力转移到了数据库上。

感谢您仔细阅读本文。希望边肖分享的文章《如何解决Hibernate批量更新的问题》对大家有所帮助。同时也希望大家多多支持,关注行业信息渠道,多了解!

内容来源网络,如有侵权,联系删除,本文地址:https://www.230890.com/zhan/137022.html

(0)

相关推荐

  • debug R命令如何修改寄存器的值

    技术debug R命令如何修改寄存器的值这期内容当中小编将会给大家带来有关debug R命令如何修改寄存器的值,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。    IDE : Masm

    攻略 2021年11月11日
  • 怎样在Vue中使用JSX

    技术怎样在Vue中使用JSX怎样在Vue中使用JSX,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。JSX是什么JSX 是一种 Javascript 的语法扩

    攻略 2021年10月21日
  • spring事件机制实例(spring事件机制详解)

    技术Spring的事件机制知识点有哪些这篇文章主要讲解了“Spring的事件机制知识点有哪些”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Spring的事件机制知识点有哪

    攻略 2021年12月20日
  • Python大神利用正则表达式教你搞定京东商品信息的示例分析

    技术Python大神利用正则表达式教你搞定京东商品信息的示例分析Python大神利用正则表达式教你搞定京东商品信息的示例分析,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能

    攻略 2021年10月25日
  • 深入理解flink实时大数据处理实践(大数据系统开发基础)

    技术怎么实现大数据处理引擎Spark与Flink比拼今天就跟大家聊聊有关怎么实现大数据处理引擎Spark与Flink比拼,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收

    攻略 2021年12月17日
  • 奶粉可以做酸奶吗,羊奶粉可以做酸奶吗

    技术奶粉可以做酸奶吗,羊奶粉可以做酸奶吗我来回答这个问题奶粉可以做酸奶吗。可以肯定的说完全可以用羊奶粉做酸奶。据说最早的酸奶出现就是因为羊奶存放不当发生的一次偶然。在以前草原的牧民,挤完大量的羊奶,由于没有冷藏保鲜的设备

    生活 2021年10月31日