我的编程空间,编程开发者的网络收藏夹
学习永远不晚

Hibernate如何实现批量处理

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

Hibernate如何实现批量处理

这篇文章给大家分享的是有关Hibernate如何实现批量处理的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。

Hibernate批量处理其实从性能上考虑,它是很不可取的,浪费了很大的内存。从它的机制上讲,Hibernate它是先把符合条件的数据查出来,放到内存当中,然后再进行操作。实际使用下来性能非常不理想,在笔者的实际使用中采用下面的第三种优化方案的数据是:100000条数据插入数据库,主流台式机的配置,需要约30分钟,呵呵,晕倒。

总结下来有三种来处理以解决性能问题:
1:绕过Hibernate API ,直接通过 JDBC API 来做,这个方法性能上是比较好的。也是最快的。
2:运用存储过程。
3:还是用Hibernate API 来进行常规的批量处理,可以也有变,变就变在,我们可以在查找出一定的量的时候,及时的将这些数据做完操作就

删掉,session.flush();session.evict(XX对象集); 这样也可以挽救一点性能损失。这个“一定的量”要就要根据实际情况做定量参考了。一般为30-60左右,但效果仍然不理想。

绕过Hibernate API ,直接通过 JDBC API 来做,这个方法性能上是比较好的,也是最快的。(实例为 更新操作)

  1. Transaction tx=session.beginTransaction();   

  2. //注意用的是hibernate事务处理边界  

  3. Connection conn=session.connection();  

  4. PreparedStatement stmt=conn.preparedStatement
    ("update CUSTOMER as C set C.sarlary=c.sarlary+1 where c.sarlary>1000");  

  5. stmt.excuteUpdate();  

  6. tx.commit();   

  7. //注意用的是hibernate事务处理边界 

这小程序中,采用的是直接调用JDBC 的API 来访问数据库,效率很高。避免了Hibernate 先查询出来加载到内存,再进行操作引发的性能问题。

运用存储过程。但这种方式考虑到易植和程序部署的方便性,不建议使用。(实例为 更新操作)

如果底层数据库(如Oracle)支持存储过程,也可以通过存储过程来执行批量更新。存储过程直接在数据库中运行,速度更加快。在Oracle数

据库中可以定义一个名为batchUpdateCustomer()的存储过程,代码如下:

  1. create or replace procedure batchUpdateCustomer(p_age in number) 
    as begin update CUSTOMERS set AGEAGE=AGE+1 where AGE>p_age;

  2. end; 

以上存储过程有一个参数p_age,代表客户的年龄,应用程序可按照以下方式调用存储过程:

tx = session.beginTransaction();  Connection con=session.connection();  String procedure = "{call batchUpdateCustomer(?) }";  CallableStatement cstmt = con.prepareCall(procedure);  cstmt.setInt(1,0);  //把年龄参数设为0  cstmt.executeUpdate();  tx.commit();

从上面程序看出,应用程序也必须绕过Hibernate API,直接通过JDBC API来调用存储过程。

感谢各位的阅读!关于“Hibernate如何实现批量处理”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,让大家可以学到更多知识,如果觉得文章不错,可以把它分享出去让更多的人看到吧!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

Hibernate如何实现批量处理

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

Hibernate如何实现批量处理

这篇文章给大家分享的是有关Hibernate如何实现批量处理的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。Hibernate批量处理其实从性能上考虑,它是很不可取的,浪费了很大的内存。从它的机制上讲,Hibern
2023-06-17

如何使用批处理文件实现批量注册dll

这篇文章主要为大家展示了“如何使用批处理文件实现批量注册dll”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“如何使用批处理文件实现批量注册dll”这篇文章吧。但是对于新手来说即使知道是DLL文件
2023-06-08

如何实现批量vps管理

这篇文章主要介绍了如何实现批量vps管理的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇如何实现批量vps管理文章都会有所收获,下面我们一起来看看吧。首先,下载解压iis7远程桌面管理工具:点击右上角的【添加】添
2023-06-02

批处理如何实现一键批量备份网站数据

这篇文章将为大家详细讲解有关批处理如何实现一键批量备份网站数据,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。把以下代码另存为AutoBAK.BAT文件放到你要打包的目录下双击执行即可!非常适合虚拟主机商批
2023-06-08

如何实现批量列出所有文件名的批处理

这篇文章给大家分享的是有关如何实现批量列出所有文件名的批处理的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。快速列出目录下的所有文件名称。 用法:把一下代码保存为*.bat格式,放到目标根目录下双击就OK了 代码如
2023-06-08

批处理中如何实现预处理

这篇文章主要为大家展示了“批处理中如何实现预处理”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“批处理中如何实现预处理”这篇文章吧。一、预处理究竟要做什么? 根据我的经验,预处理要做的是变量值的替
2023-06-08

如何解决Hibernate批量更新问题

这篇文章主要介绍了如何解决Hibernate批量更新问题,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。对于Hibernate批量更新操作,Hibernate是将符合要求的数据
2023-06-17

如何实现批处理加密.bat

这篇文章给大家分享的是有关如何实现批处理加密.bat的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。代码如下:%%a %%a %%a %%a %%a %%a %%a %%a %%a %%a %%a %%a %%a
2023-06-09

Python实现文件名批量处理

我们知道文件名是可以手动修改的,但是如果要同时修改多个文件名,那一个一个修改会浪费掉很多时间,此时我们就可以考虑使用python来实现文件名的批量处理。想要批量处理文件名首先确定需要处理的文件名,以及确定处理后新的文件名,这样就可以开始处理
2023-06-02

如何实现批处理bat后门

这篇文章将为大家详细讲解有关如何实现批处理bat后门,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。代码如下:@echo off @attrib +s + r xyt.bat @net use
2023-06-09

批处理如何实现倒计时

这篇文章主要为大家展示了“批处理如何实现倒计时”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“批处理如何实现倒计时”这篇文章吧。代码如下:@echo off echo exit|%ComSpec%
2023-06-09

批处理如何实现数码雨

小编给大家分享一下批处理如何实现数码雨,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!代码如下:@echo off color 0a :start set num=
2023-06-09

如何实现批处理蠕虫bat

这篇文章主要介绍了如何实现批处理蠕虫bat,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。代码如下:@echo off attrib -r -h -s "%~nx0" 2>n
2023-06-09

如何实现恶意批处理.bat

这篇文章主要介绍如何实现恶意批处理.bat,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!@echo off title You DEAD!!!!!!! set taskkill=s copy %0 %windir%\
2023-06-09

批处理如何实现OFFICE复位

这篇文章主要为大家展示了“批处理如何实现OFFICE复位”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“批处理如何实现OFFICE复位”这篇文章吧。代码如下:@echo of rem 当WORD\
2023-06-09

ps如何批量处理图片

本文小编为大家详细介绍“ps如何批量处理图片”,内容详细,步骤清晰,细节处理妥当,希望这篇“ps如何批量处理图片”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。ps动作批量处理图片:1、首先进入ps软件,然后点击窗
2023-07-02

如何实现远程批量修改计算机IP设置的批处理

这篇文章主要介绍了如何实现远程批量修改计算机IP设置的批处理,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。网络IP设置远处更改脚本。 当网络整改需要大量IP修改的时候,可利用
2023-06-08

如何实现批处理实现乱雨纷飞

这篇文章主要介绍“如何实现批处理实现乱雨纷飞”,在日常操作中,相信很多人在如何实现批处理实现乱雨纷飞问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”如何实现批处理实现乱雨纷飞”的疑惑有所帮助!接下来,请跟着小编
2023-06-08

Python+wxPython实现文件名批量处理

正文本文档展示了如何使用wxPython创建一个简单的批量文件处理应用程序。该应用程序包括一个文本框,允许用户输入要处理的文件名。当用户单击"处理"按钮时,应用程序会对每个文件名执行指定的操作。可以根据文件扩展名定制处理过程。此外,本文档还提供了其他注意事项和扩展功能。
Python+wxPython实现文件名批量处理
2024-04-23

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录