首頁 資料庫 mysql教程 Ibatis之RowHandler

Ibatis之RowHandler

Jun 07, 2016 pm 04:06 PM
ibatis 進行

当用Ibatis进行大数据量Sql查询时(如上百万条,千万条数据),如果按照一般的编程方式(如QueryForList方法)把数据查询出来再做操作则很可能会出现性能问题,如: 1.对JVM内存的大量消耗; 2.大量对象的密集创建对GC带来一定的压力; 3.数据查询和后续的数

当用Ibatis进行大数据量Sql查询时(如上百万条,千万条数据),如果按照一般的编程方式(如QueryForList方法)把数据查询出来再做操作则很可能会出现性能问题,如:
1.对JVM内存的大量消耗;
2.大量对象的密集创建对GC带来一定的压力;
3.数据查询和后续的数据操作无法并行执行等

为应对这样的场景,Ibatis提供了RowHandler接口,以回调的方式,允许用户对查询结果集进行自定义的处理,用户通过自定义实现handleRow方法一次处理一条数据,从而提高框架的灵活性。

/**
 * Event handler for row by row processing.
 * <p/>
 * The RowHandler interface is used by the SqlMapSession.queryWithRowHandler() method.
 * Generally a RowHandler implementation will perform some row-by-row processing logic
 * in cases where there are too many rows to efficiently load into memory.
 * <p/>
 * Example:
 * <pre class="brush:php;toolbar:false">
 * sqlMap.queryWithRowHandler ("findAllEmployees", null, new MyRowHandler()));
 * 
登入後複製
*/ public interface RowHandler { /** * Handles a single row of a result set. *

* This method will be called for each row in a result set. For each row the result map * will be applied to build the value object, which is then passed in as the valueObject * parameter. * * @param valueObject The object representing a single row from the query. * @see com.ibatis.sqlmap.client.SqlMapSession */ void handleRow(Object valueObject); }

简单举例来说RowHandler的作用:
在大数据量的场景下,如:银行每天对账户的“计提”操作,如果有一千万个账户,则需要查询出一千万条账号,然后做一千万次更新(如果可以用addbatch那就肯定不用一千万次了)。为了尽可能提升性能:
1.必须防止对象爆发式的创建,因为爆发式创建会让内存急剧上升,如果没有很好的设计,还会导致对象爆发式的销毁(即:对最后一条数据处理完才会让所有对象失效,而在进行这一千万次更新期间这些内存都是被占用的)。通过自定义RowHandler,可以对数据逐条进行处理,在handleRow方法中执行更新操作,更新完之后立刻释放对象,这样便对操作进行了“离散化”,降低了对内存的占用。
2.上面通过“离散化”解决了内存占用的问题,但查询和数据处理的总时间是没有减少的,为了达到更高的效率,还需要进行“异步化”处理。在handleRow方法中,将valueObject发送到异步队列中,让查询和执行进行并行处理,进而降低总时间。其实总时间的降低体现出的只是一个优点,还有一个优点就是:进行“异步化”之后的查询时间和直接调用QueryForList的查询时间相差不会太大,查询完之后就快速释放连接了,减轻了数据库的压力。


注意事项:
当应用RowHandler时,可能仍然会发现内存急剧上升,这是因为底层JDBC返回的ResultMap仍然会一次性把数据全部返回的缘故。通过设置fetchsize可以解决这一问题,fetchsize是JDBC提供的一个配置变量,JDBC驱动按照该变量的配置值从数据库中循环取数据,而不是一次性load到内存中,这样便允许用户根据自己的实际情况做最优的参数设置,ibatis的select标签将此属性暴露了出来,可以针对某个特定的语句做独立的设置,以达到最优的性能。但是fetchsize也不能太小,否则会带来java和数据库之间频繁的交互,内存问题倒是解决了,但是频繁交互带来的性能问题又出现了,所以fetchsize的值需要以具体场景和实验数据为依据进行灵活设置。
关于fetchsize的几个链接:
http://www.2cto.com/database/201305/209625.html
http://www.java3z.com/cwbwebhome/article/article8/828.html?id=2244
http://www.smithfox.com/?e=153
http://stackoverflow.com/questions/3870500/ibatis-querywithrowhandler-still-seems-to-fetch-all-rows
http://docs.aws.amazon.com/redshift/latest/dg/jdbc-fetch-size-parameter.html

利用rowhandler还可以实现对象关联关系的创建,解决“N+1 Select“的问题,此处不详述,备忘一下,详见《Ibatis in Action》一书的相关章节。
rowhandler可以做的事情其实很多,它是一种公用的机制,只是经常被用来解决效率问题,当Ibatis框架不能满足我们的需求时,可以考虑发挥该接口的作用。
至于性能,本文说的都是偏理论的、一般性的场景,具体的解决方案需要因场景而异,经验结合需求才能得到最好的设计。

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

iBatis和MyBatis:哪個比較適合你? iBatis和MyBatis:哪個比較適合你? Feb 19, 2024 pm 04:38 PM

iBatis與MyBatis:你該選擇哪一個?簡介:隨著Java語言的快速發展,許多持久化框架也應運而生。 iBatis和MyBatis是兩個備受歡迎的持久化框架,它們都提供了一個簡單而高效的資料存取解決方案。本文將介紹iBatis和MyBatis的特點和優勢,並給出一些具體的程式碼範例,幫助你選擇合適的框架。 iBatis簡介:iBatis是一個開源的持久化框架

iBatis與MyBatis:比較與優勢剖析 iBatis與MyBatis:比較與優勢剖析 Feb 18, 2024 pm 01:53 PM

iBatis和MyBatis:區別和優勢解析導語:在Java開發中,持久化是一個常見的需求,而iBatis和MyBatis是兩個廣泛使用的持久化框架。雖然它們有很多相似之處,但也有一些關鍵的區別和優勢。本文將透過詳細分析這兩個框架的特性、用法和範例程式碼,為讀者提供更全面的了解。一、iBatis特性:iBatis是目前較老舊的持久化框架,它使用SQL映射文件

ibatis和mybatis有什麼差別 ibatis和mybatis有什麼差別 Jan 10, 2024 am 11:25 AM

ibatis和mybatis的區別:1、基本資訊不同;2、開發時間不同;3、功能與易用性;4、配置;5、入參類型與出參類型;6、返回結果集接受方式;7 、文法差異;8、資料庫方言支援;9、插件支援;10、社區活躍度;11、全球化支援。詳細介紹:1、基本資訊不同,iBatis提供持久層框架,包括SQL Maps和Data Access Objects等等。

iBatis與MyBatis的異同比較:主流ORM框架的對比 iBatis與MyBatis的異同比較:主流ORM框架的對比 Feb 19, 2024 pm 07:08 PM

iBatis和MyBatis是兩個主流的ORM(Object-RelationalMapping)框架,它們在設計和使用上有著許多相似之處,也存在一些細微的差別。本文將詳細比較iBatis和MyBatis的異同,並透過具體的程式碼範例來說明它們的特點。一、iBatis與MyBatis的歷史與背景iBatis是ApacheSoftwareFoundat

iBatis與MyBatis:歷史與現況的比較評價 iBatis與MyBatis:歷史與現況的比較評價 Feb 19, 2024 am 10:42 AM

iBatis和MyBatis:從歷史到現狀的評估與對比引言:隨著軟體開發領域的快速發展,對於資料庫存取框架也提出了越來越高的要求。 iBatis和MyBatis是兩個備受關注的Java持久層框架,它們都提供了一種簡單靈活的方式來存取關聯式資料庫。本文將對這兩個框架進行歷史回顧,並對它們的現狀進行評估與對比。一、歷史回顧iBatisiBatis是由Clinton

使用Python進行RFM分析 使用Python進行RFM分析 Sep 03, 2023 pm 12:45 PM

Python是一種多功能的程式語言,在資料分析和機器學習領域廣受歡迎。其簡潔性、可讀性和豐富的函式庫使其成為處理複雜資料任務的理想選擇。其中一個強大的應用是RFM分析,這是一種在行銷中根據客戶購買行為進行分割的技術。在本教程中,我們將透過使用Python來實施RFM分析的過程來指導您。我們將從解釋RFM分析的概念及其在行銷中的重要性開始。然後,我們將逐步深入探討使用Python進行RFM分析的實際面向。在文章的下一部分中,我們將示範如何使用Python為每個客戶計算RFM分數,考慮到為最近性、頻率和

《黒神話:悟空》Xbox 版被曝因「記憶體洩漏」而延期,PS5 版優化進行中 《黒神話:悟空》Xbox 版被曝因「記憶體洩漏」而延期,PS5 版優化進行中 Aug 27, 2024 pm 03:38 PM

近日,《黑神話:悟空》在全球範圍內都引發了巨大的關注,各平台的同時在線人數都再創新高,這款遊戲在多個平台取得了巨大的商業成功。 《黑神話:悟空》的Xbox版延期雖然《黑神話:悟空》已於PC和PS5平台發布,但其Xbox版一直沒有確切消息。據了解,官方已確認《黑神話:悟空》將登陸Xbox平台。但具體上線日期尚未公佈。最近有消息稱,Xbox版的延期是由於技術問題所致。據相關部落客透露,他在Gamescom期間與開發人員和"Xbox內部人士"的交流中得知,《黑神話:悟空》的Xbox版存

ibatis mysql 亂碼怎麼解決 ibatis mysql 亂碼怎麼解決 Feb 16, 2023 am 10:40 AM

ibatis mysql亂碼的解決方法:1、檢查mysql的字元集,並設定為utf8;2、將設定修改為「<property name="url"><value><![CDATA[jdbc:mysql://localhost :3306/yourDbNameuseUnicode=TRUE&characterEncoding=utf8]]></value>」即可。

See all articles