溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

Hibernate持久化類怎么用

發(fā)布時間:2021-12-01 10:45:48 來源:億速云 閱讀:155 作者:小新 欄目:編程語言

這篇文章主要介紹了Hibernate持久化類怎么用,具有一定借鑒價值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。

Hibernate持久化類使用的是JavaBean的風(fēng)格,為要被訪問的屬性提供了一套get和set方法,這兩個方法也叫做Hibernate持久化類的訪問方法.記得曾經(jīng)在接觸JavaBean 的時候我很迷糊,總覺得提供這兩個方法,倒不如把Bean的屬性設(shè)置public,然后直接調(diào)用對象.屬性,這樣來的方便.但是后來,有一個這樣的需求, 就是一個人名字可以被查看,但是不可以修改.這個時候如果用set方法的話,只需要把set方法的修飾符換為private就OK了.如果是用對象.屬性的形式調(diào)用就麻煩了。

而且最重要的一個有點是JavaBean的風(fēng)格可以簡化Hibernate通過JAVA反射機制來獲得Hibernate持久化類的訪問方法的過程,至于JAVA的反射機制我也是了解一些皮毛.據(jù)說很深奧.有興趣的朋友可以Google一下.有一點值得注意,就是JAVA應(yīng)用程序不能訪問JavaBean持久化類的private類型的get,set方法.而Hibernate沒有這個限制,可以訪問所有的級別.包括private default,protected,public.

Java有8種基本類型:byte,short,char,int,long,float,double,boolean,還有8種與之對應(yīng)的包裝類型,Byte,Short,Character,Integer,Long,F(xiàn)loat,Double,Boolean包裝類型就是把基本類型包裝成對象的意思.基本類型于包裝類型之間可以方便的轉(zhuǎn)換,例如:

int i = 0;  Integer ie = new Integer(i);  //基本類型轉(zhuǎn)換成包裝類型  i = ie.intValue();  //包裝類型轉(zhuǎn)化成基本類型

注意,直接轉(zhuǎn)換也是可以的.例如i = ie; JAVA會自動把包裝類型轉(zhuǎn)換成基本類型.或者ie = i; JAVA會自動把基本類型轉(zhuǎn)換成包裝類型.在Hibernate持久化類中,既可以把屬性定義為基本類型,也可以定義為包裝類型,他們對應(yīng)的Hibernate映射類型int和Integer都對應(yīng)int類型,這個表示不是很明顯,在用JAVA對象類型字符串舉例String,數(shù)據(jù)庫是varhcar(50),在hibernate的*.hbm.xml 映射文件里一律寫為string。

其實使用基本類型或者包裝類型來定義Hibernate持久化類中的屬性是各有優(yōu)缺點的.基本類型就是使用方便,簡單,在需要數(shù)字運算的時候直接可以運算.而包裝類型就要麻煩的先轉(zhuǎn)換成基本類型,然后在進行運算,但是包裝類型的優(yōu)點在于能表達null值,每一個包裝類型的對象創(chuàng)建的時候默認值都是null類型的.而基本類型是不可以表達null的,它們的默認值是0.為什么要表達null值呢.因為SQL中.所有類型的數(shù)據(jù),默認值都是 null的。

當進入insert的時候,沒有復(fù)值的屬性,默認值就是null,所以說JAVA的包裝類型和數(shù)據(jù)庫之間的對應(yīng)關(guān)系更直接.這里建議Hibernate的OID設(shè)置為包裝類型,其他的屬性就根據(jù)業(yè)務(wù)需要和個人習(xí)慣來定吧.

Hibernate在初始化階段會根據(jù)映射文件的信息,為所有的Hibernate持久化類預(yù)定義insert語句,update語句where ID,delete語句where ID,select語句where ID,這里所說的語句就是標準的SQL增,刪,改,查.語句,參數(shù)用?代表JDBC PreparedStatement中的參數(shù),這里就不舉例了.這些SQL語句都存放在SessionFactory的緩存中,當執(zhí)行Session的 save(),update(),delete(),load()方法時,將會從SessionFactory的緩存中讀取這些預(yù)定義的SQL語句,在把具體的參數(shù)值綁定到SQL語句中,這就是Hibernate的基本原理.在默認的情況下這些語句表達的是所有的字段.當然Hibernate還允許我們在映射文件里控制insert和update語句的內(nèi)容。

比如在映射文件中<property 元素中的update屬性設(shè)置成為false,那么這個字段,將不被包括在基本的update語句中,修改的時候,將不包括這個字段了.insert同理.dynamic動態(tài)SQL語句的配置也是很常用的.下面介紹配置SQL語句的具體屬性:
1)<property>元素 insert屬性:設(shè)置為false,在insert語句中不包含這個字段,表示永遠不會被插入,默認true
2)<property>元素 update屬性:設(shè)置為false,在update語句中不包含這個字段,表示永遠不會被修改,默認true
3)<class>元素 mutable屬性:設(shè)置為false就是把所有的<property>元素的update屬性設(shè)置為了false,說明這個對象不會被更新,默認true
4)<property>元素 dynamic-insert屬性:設(shè)置為true,表示insert對象的時候,生成動態(tài)的insert語句,如果這個字段的值是null就不會加入到insert語句當中.默認false
5)<property>元素 dynamic-update屬性,設(shè)置為true,表示update對象的時候,生成動態(tài)的update語句,如果這個字段的值是null就不會被加入到update語句中,默認false
6)<class>元素 dynamic-insert屬性:設(shè)置為true,表示把所有的<property>元素的dynamic-insert屬性設(shè)置為true,默認false
7)<class>元素 dynamic-update屬性:設(shè)置為true,表示把所有的<property>元素的dynamic-update屬性設(shè)置為true,默認false

Hibernate生成動態(tài)SQL語句的消耗的系統(tǒng)資源(比如CPU,內(nèi)存等)是很小的,所以不會影響到系統(tǒng)的性能,如果表中包含N多字段,建議把dynamic- update屬性和insert屬性設(shè)置為true,這樣在插入和修改數(shù)據(jù)的時候,語句中只包括要插入或者修改的字段.可以節(jié)省SQL語句的執(zhí)行時間,提高程序的運行效率.

感謝你能夠認真閱讀完這篇文章,希望小編分享的“Hibernate持久化類怎么用”這篇文章對大家有幫助,同時也希望大家多多支持億速云,關(guān)注億速云行業(yè)資訊頻道,更多相關(guān)知識等著你來學(xué)習(xí)!

向AI問一下細節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI