日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

hibernate java内存一次能取多少条_Hibernate管理Session和批量操作分析

發(fā)布時間:2024/1/23 编程问答 33 豆豆
生活随笔 收集整理的這篇文章主要介紹了 hibernate java内存一次能取多少条_Hibernate管理Session和批量操作分析 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

本文詳細(xì)分析了Hibernate管理Session和批量操作的用法。分享給大家供大家參考。具體分析如下:

Hibernate管理Session

Hibernate自身提供了三種管理Session對象的方法

① Session對象的生命周期與本地線程綁定

② Session對象的生命周期與JTA事務(wù)綁定

③ Hibernate委托程序管理Session對象的生命周期

在Hibernate的配置文件中,hibernate.current_session_context_class屬性用于指定Session管理方式,可選值包括:

① thread:Session對象的生命周期與本地線程綁定

② jta*:Session對象的生命周期與JTA事務(wù)綁定

③ managed:Hibernate委托程序來管理Session對象的生命周期

Session對象的生命周期與本地線程綁定:如果把Hibernate配置文件的hibernate.current_session_context_class屬性值設(shè)置為thread,Hibernate就會按照與本地線程綁定的方式來管理Session

Hibernate按以下規(guī)則把Session與本地線程綁定:

當(dāng)一個線程(thread)第一次調(diào)用SessionFactory對象的getCurrentSession()方法時,該方法會創(chuàng)建一個新的Session(sessionA)對象,把該對象與threadA綁定,并將session返回

當(dāng)threadA再次調(diào)用SessionFactory對象的getCurrentSession()方法時,該方法將返回sessionA對象

當(dāng)threadA提交sessionA對象關(guān)聯(lián)的事務(wù)時,Hibernate會自動flush sessionA對象的緩存,然后提交事務(wù),關(guān)閉session隨心。當(dāng)threadA撤銷sessionA對象關(guān)聯(lián)的事務(wù)時,也會自動關(guān)閉sessionA對象

若threadA再次調(diào)用SessionFactory對象的getCurrentSession()方法時,該方法會又創(chuàng)建一個新的Session(sessionB)對象,把該對象與threadA綁定,并將sessionB返回

批量處理數(shù)據(jù)

批量處理數(shù)據(jù)是指在一個事務(wù)中處理大量數(shù)據(jù)

在應(yīng)用層進(jìn)程批量操作,主要有以下方式:

① 通過Session

② 通過HQL

③ 通過StatelessSession

④ 通過JDBC API----推薦此種,因為速度最快

Session進(jìn)行批量操作:

Session的save()及update()方法都會把處理的對象存放在自己的緩存中。如果通過一個Session對象來處理大量持久化對象,應(yīng)該及時從緩存中清空已經(jīng)處理完畢并且不會再訪問的對象。具體的做法是在處理完一個對象或小批量對象后,立即調(diào)用flush()方法刷新緩存,然后再調(diào)用clear()方法情況緩存

通過Session來進(jìn)行處理操作會受到以下約束:

需要在Hibernate配置文件中設(shè)置JDBC單次批量處理的數(shù)目,應(yīng)保證每次向數(shù)據(jù)庫發(fā)送的批量的SQL語句數(shù)目與batch size屬性一致

若對象采用"identity"標(biāo)識生成器,則Hibernate無法在JDBC曾進(jìn)行批量插入操作

進(jìn)行批量操作時,建議關(guān)閉Hibernate的二級緩存

批量插入數(shù)據(jù)代碼演示:

News news = null;

for(int i = 0; i < 10000; i++) {

news = new News();

news.setTitle("--" + i);

session.save(news);

if((i + 1) % 20 == 0) {

session.flush();

session.clear();

}

}

批量更新:在進(jìn)行批量更新時,如果一下子把所有對象都加載到Session緩存,然后再緩存中一一更新,顯然是不可取的

使用可滾動的結(jié)果集org.hibernate.ScrollableResults,該對象中實際上并不包含任何對象,只包含用于在線定位記錄的游標(biāo)。只有當(dāng)程序遍歷訪問ScrollableResults對象的特定元素時,它才會到數(shù)據(jù)庫中加載相應(yīng)的對象

org.hibernate.ScrollableResults對象由Query的scroll方法返回

通過HQL進(jìn)行批量操作:

注意:HQL只支持INSERT INTO ... SELECT形式的插入語句,但不支持INSERT INTO ... VALUES形式的插入語句。所以使用HQL不能進(jìn)行批量插入操作

通過StatelessSession進(jìn)行批量操作:

從形式上看,StatelessSession與Session的用法類似。StatelessSession與Session相比,有以下區(qū)別:

StatelessSession沒有緩存,通過StatelessSession來加載、保存或更新后的對象處于游離狀態(tài)

StatelessSession不會與Hibernate的二級緩存交互

當(dāng)調(diào)用StatelessSession的save()、update()或delete()方法時,這些方法會立即執(zhí)行相應(yīng)的SQL語句,而不會僅計劃執(zhí)行一條SQL語句

StatelessSession不會進(jìn)行臟檢查,因此修改了Customer對象屬性后,還需要調(diào)用StatelessSession的update()方法來更新數(shù)據(jù)庫中數(shù)據(jù)

StatelessSession不會對關(guān)聯(lián)的對象進(jìn)行任何的級聯(lián)操作

通過同一個StatelessSession對象兩次加載的OID為1的Customer對象,得到的兩個對象內(nèi)存地址不同

StatelessSession所做的操作可以被Interceptor攔截器捕獲到,但是會被Hibernate的事件處理系統(tǒng)忽略掉

希望本文所述對大家的Java程序設(shè)計有所幫助。

總結(jié)

以上是生活随笔為你收集整理的hibernate java内存一次能取多少条_Hibernate管理Session和批量操作分析的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。