偷偷摘套内射激情视频,久久精品99国产国产精,中文字幕无线乱码人妻,中文在线中文a,性爽19p

Hibernate issue入門手冊(cè)

開發(fā) 后端
對(duì)于并發(fā)Insert要求較高的系統(tǒng),推薦采用uuid.hex作為主鍵生成機(jī)制。 本文是對(duì)Hibernate issue入門具體分析與概述。

本文向大家介紹Hibernate issue,可能好多人還不了解Hibernate issue,沒有關(guān)系,看完本文你肯定有不少收獲,希望本文能教會(huì)你更多東西。

1.在Hibernate中進(jìn)行多表查詢,每個(gè)表中各取幾個(gè)字段,也就是說查詢出來的結(jié)果集并沒有一個(gè)實(shí)體類與之對(duì)應(yīng),如何解決這個(gè)問題? 

◆解決方案一,按照t數(shù)據(jù)取出數(shù)據(jù),然后自己組bean

◆解決方案二,對(duì)每個(gè)表的bean寫構(gòu)造函數(shù),比如表一要查出field1,field2兩個(gè)字段,那么有一個(gè)構(gòu)造函數(shù)就是Bean(type1filed1,type2field2),然后在hql里面就可以直接生成這個(gè)bean了。

2.session.load()和session.get()的區(qū)別 

Session.load/get方法均可以根據(jù)指定的實(shí)體類和id從數(shù)據(jù)庫讀取記錄,并返回與之對(duì)應(yīng)的實(shí)體對(duì)象。

其區(qū)別在于:

◆如果未能發(fā)現(xiàn)符合條件的記錄,get方法返回null,而load方法會(huì)拋出一個(gè)tNotFoundException。

◆Load方法可返回實(shí)體的代理類實(shí)例,而get方法永遠(yuǎn)直接返回實(shí)體類。

◆load方法可以充分利用內(nèi)部緩存和二級(jí)緩存中的現(xiàn)有數(shù)據(jù),而get方法則僅僅在內(nèi)部緩存中進(jìn)行數(shù)據(jù)查找,如沒有發(fā)現(xiàn)對(duì)應(yīng)數(shù)據(jù),將越過二級(jí)緩存,直接調(diào)用SQL完成數(shù)據(jù)讀取。

Session在加載實(shí)體對(duì)象時(shí),將經(jīng)過的過程:

首先,Hibernate中維持了兩級(jí)緩存。***級(jí)緩存由Session實(shí)例維護(hù),其中保持了Session當(dāng)前所有關(guān)聯(lián)實(shí)體的數(shù)據(jù),也稱為內(nèi)部緩存。而第二級(jí)緩存則存在于SessionFactory層次,由當(dāng)前所有由本SessionFactory構(gòu)造的Session實(shí)例共享。

出于性能考慮,避免無謂的數(shù)據(jù)庫訪問,Session在調(diào)用數(shù)據(jù)庫查詢功能之前,會(huì)先在緩存中進(jìn)行查詢。首先在***級(jí)緩存中,通過實(shí)體類型和id進(jìn)行查找,如果***級(jí)緩存查找命中,且數(shù)據(jù)狀態(tài)合法,則直接返回。

之后,Session會(huì)在當(dāng)前“NonExists”記錄中進(jìn)行查找,如果“NonExists”記錄中存在同樣的查詢條件,則返回null?!癗onExists”記錄了當(dāng)前Session實(shí)例在之前所有查詢操作中,未能查詢到有效數(shù)據(jù)的查詢條件(相當(dāng)于一個(gè)查詢黑名單列表)。如此一來,如果Session中一個(gè)無效的查詢條件重復(fù)出現(xiàn),即可迅速作出判斷,從而獲得***的性能表現(xiàn)。

對(duì)于load方法而言,如果內(nèi)部緩存中未發(fā)現(xiàn)有效數(shù)據(jù),則查詢第二級(jí)緩存,如果第二級(jí)緩存命中,則返回。如在緩存中未發(fā)現(xiàn)有效數(shù)據(jù),則發(fā)起數(shù)據(jù)庫查詢操作(SelectSQL),如經(jīng)過查詢未發(fā)現(xiàn)對(duì)應(yīng)記錄,則將此次查詢的信息在“NonExists”中加以記錄,并返回null。

根據(jù)映射配置和Select SQL得到的ResultSet,創(chuàng)建對(duì)應(yīng)的數(shù)據(jù)對(duì)象。將其數(shù)據(jù)對(duì)象納入當(dāng)前Session實(shí)體管理容器(一級(jí)緩存)。執(zhí)行Interceptor.onLoad方法(如果有對(duì)應(yīng)的Interceptor)。將數(shù)據(jù)對(duì)象納入二級(jí)緩存。如果數(shù)據(jù)對(duì)象實(shí)現(xiàn)了LifeCycle接口,則調(diào)用數(shù)據(jù)對(duì)象的onLoad方法返回?cái)?shù)據(jù)對(duì)象。

3.Hibernate的主鍵生成機(jī)制

1) assigned 主鍵由外部程序負(fù)責(zé)生成,無需Hibernate參與。

2) hilo 通過hi/lo 算法實(shí)現(xiàn)的主鍵生成機(jī)制,需要額外的數(shù)據(jù)庫表保存主鍵生成歷史狀態(tài)。

3) seqhilo 與hilo類似,通過hi/lo算法實(shí)現(xiàn)的主鍵生成機(jī)制,只是主鍵歷史狀態(tài)保存在Sequence中,適用于支Sequence的數(shù)據(jù)庫,如Oracle。

4) increment 主鍵按數(shù)值順序遞增。

此方式的實(shí)現(xiàn)機(jī)制為在當(dāng)前應(yīng)用實(shí)例中維持一個(gè)變量,以保存著當(dāng)前的***值,之后每次需要生成主鍵的時(shí)候?qū)⒋酥导?作為主鍵。這種方式可能產(chǎn)生的問題是:如果當(dāng)前有多個(gè)實(shí)例訪問同一個(gè)數(shù)據(jù)庫,那么由于各個(gè)實(shí)例各自維護(hù)主鍵狀態(tài),不同實(shí)例可能生成同樣的主鍵,從而造成主鍵重復(fù)異常。因此,如果同一數(shù)據(jù)庫有多個(gè)實(shí)例訪問,此方式必須避免使用。

5) identity 采用數(shù)據(jù)庫提供的主鍵生成機(jī)制。如DB2、SQL Server、MySQL中的主鍵生成機(jī)制。

6) sequence 采用數(shù)據(jù)庫提供的sequence 機(jī)制生成主鍵。如Oralce 中的Sequence。

7) native 由Hibernate根據(jù)底層數(shù)據(jù)庫自行判斷采用identity、hilo、sequence其中一種作為主鍵生成方式。

8) uuid.hex 由Hibernate基于128 位唯一值產(chǎn)生算法生成16 進(jìn)制數(shù)值(編碼后以長度32 的字符串表示)作為主鍵。

9) uuid.string 與uuid.hex 類似,只是生成的主鍵未進(jìn)行編碼(長度16)。在某些數(shù)據(jù)庫中可能出現(xiàn)問題(如PostgreSQL)。

10) foreign 使用外部表的字段作為主鍵。一般而言,利用uuid.hex方式生成主鍵將提供***的性能和數(shù)據(jù)庫平臺(tái)適應(yīng)性。

這10中生成OID標(biāo)識(shí)符的方法,increment比較常用,把標(biāo)識(shí)符生成的權(quán)力交給Hibernate處理.但是當(dāng)同時(shí)多個(gè)Hibernate應(yīng)用操作同一個(gè)數(shù)據(jù)庫,甚至同一張表的時(shí)候.就推薦使用identity依賴底層數(shù)據(jù)庫實(shí)現(xiàn),但是數(shù)據(jù)庫必須支持自動(dòng)增長,當(dāng)然針對(duì)不同的數(shù)據(jù)庫選擇不同的方法.如果你不能確定你使用的數(shù)據(jù)庫具體支持什么的情況下.可以選擇用native讓Hibernate來幫選擇identity,sequence,或hilo.

另外由于常用的數(shù)據(jù)庫,如Oracle、DB2、SQLServer、MySql等,都提供了易用的主鍵生成機(jī)制(Auto-Increase字段或者Sequence)。我們可以在數(shù)據(jù)庫提供的主鍵生成機(jī)制上,采用generator-class=native的主鍵生成方式。

不過值得注意的是,一些數(shù)據(jù)庫提供的主鍵生成機(jī)制在效率上未必***,大量并發(fā)insert數(shù)據(jù)時(shí)可能會(huì)引起表之間的互鎖。數(shù)據(jù)庫提供的主鍵生成機(jī)制,往往是通過在一個(gè)內(nèi)部表中保存當(dāng)前主鍵狀態(tài)(如對(duì)于自增型主鍵而言,此內(nèi)部表中就維護(hù)著當(dāng)前的***值和遞增量),之后每次插入數(shù)據(jù)會(huì)讀取這個(gè)***值,然后加上遞增量作為新記錄的主鍵,之后再把這個(gè)新的***值更新回內(nèi)部表中,這樣,一次Insert操作可能導(dǎo)致數(shù)據(jù)庫內(nèi)部多次表讀寫操作,同時(shí)伴隨的還有數(shù)據(jù)的加鎖解鎖操作,這對(duì)性能產(chǎn)生了較大影響。

因此,對(duì)于并發(fā)Insert要求較高的系統(tǒng),推薦采用uuid.hex作為主鍵生成機(jī)制。 以上是對(duì)Hibernate issue入門概述。

責(zé)任編輯:仲衡 來源: javaeye
相關(guān)推薦

2009-09-24 15:03:30

Hibernate配置

2009-09-24 15:27:41

Hibernate查詢

2009-09-23 11:21:32

學(xué)習(xí)Hibernate

2010-06-08 16:23:22

UML教程

2010-09-28 09:33:25

DOM模型

2009-06-02 14:46:26

Hibernate關(guān)系映射教程

2010-06-13 14:01:50

UML學(xué)習(xí)入門

2010-09-28 14:08:28

DOM

2009-06-25 16:52:34

2014-05-12 10:37:41

2010-07-20 13:19:16

Perl入門手冊(cè)

2025-02-24 10:07:10

2009-06-30 14:02:00

hibernate入門MyEclipse開發(fā)

2010-07-26 11:19:19

Perl入門手冊(cè)

2012-03-06 15:41:16

jQuery MobijQuery Mobi手冊(cè)

2010-07-16 17:23:57

Perl面向?qū)ο缶幊?/a>

2010-05-12 14:12:44

Meego開發(fā)

2009-09-23 11:37:31

Hibernate S

2009-06-11 19:54:19

Hibernate入門

2009-09-23 17:56:45

JSF入門
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)