主要區(qū)別在于是否延遲加載。
load方法
不會(huì)立即訪問(wèn)數(shù)據(jù)庫(kù),當(dāng)試圖加載的記錄不存在時(shí),load方法返回一個(gè)未初始化的代理對(duì)象。
get方法
總是立即訪問(wèn)數(shù)據(jù)庫(kù)。當(dāng)試圖加載的記錄不存在時(shí),直接返回null
在hibernate中發(fā)現(xiàn)有2個(gè)方法很雷同。查閱后發(fā)現(xiàn)
Hibernate中有兩個(gè)極為相似的方法get()與load(),他們都可以通過(guò)指定的實(shí)體類(lèi)與ID從數(shù)據(jù)庫(kù)中讀取數(shù)據(jù),并返回對(duì)應(yīng)的實(shí)例,但Hibernate不會(huì)搞兩個(gè)完全一樣的方法的,它們間的不同在于:
get是直接查詢(xún)數(shù)據(jù)庫(kù),如果查不到就返回null ,Load會(huì)首先從內(nèi)存中裝載,如果以前沒(méi)有裝載或查詢(xún)出來(lái),才開(kāi) 始查詢(xún)數(shù)據(jù)庫(kù).
hibernate中g(shù)et方法和load方法的根本區(qū)別在于:如果你使用load方法,hibernate認(rèn)為該id對(duì)應(yīng)的對(duì)象(數(shù)據(jù)庫(kù)記錄)在數(shù)據(jù)庫(kù)中是一定存在的,所以它可以放心的使用,它可以放心的使用代理來(lái)延遲加載該對(duì)象。在用到對(duì)象中的其他屬性數(shù)據(jù)時(shí)才查詢(xún)數(shù)據(jù)庫(kù),但是萬(wàn)一數(shù)據(jù)庫(kù)中不存在該記錄,那沒(méi)辦法,只能拋異常,所說(shuō)的load方法拋異常是指在使用該對(duì)象的數(shù)據(jù)時(shí),數(shù)據(jù)庫(kù)中不存在該數(shù)據(jù)時(shí)拋異常,而不是在創(chuàng)建這個(gè)對(duì)象時(shí)。由于session中的緩存對(duì)于hibernate來(lái)說(shuō)是個(gè)相當(dāng)廉價(jià)的資源,所以在load時(shí)會(huì)先查一下session緩存看看該id對(duì)應(yīng)的對(duì)象是否存在,不存在則創(chuàng)建代理。所以如果你知道該id在數(shù)據(jù)庫(kù)中一定有對(duì)應(yīng)記錄存在就可以使用load方法來(lái)實(shí)現(xiàn)延遲加載。 對(duì)于get方法,hibernate會(huì)確認(rèn)一下該id對(duì)應(yīng)的數(shù)據(jù)是否存在,首先在session緩存中查找,然后在二級(jí)緩存中查找,還沒(méi)有就查數(shù)據(jù)庫(kù),數(shù)據(jù)庫(kù)中沒(méi)有就返回null。
2.get方法首先查詢(xún)session緩存,沒(méi)有的話查詢(xún)二級(jí)緩存,最后查詢(xún)數(shù)據(jù)庫(kù);反而load方法創(chuàng)建時(shí)首先查詢(xún)session緩存,沒(méi)有就創(chuàng)建代理,實(shí)際使用數(shù)據(jù)時(shí)才查詢(xún)二級(jí)緩存和數(shù)據(jù)庫(kù)。
總之對(duì)于get和load的根本區(qū)別,一句話,hibernate對(duì)于load方法認(rèn)為該數(shù)據(jù)在數(shù)據(jù)庫(kù)中一定存在,可以放心的使用代理來(lái)延遲加載,如果在使用過(guò)程中發(fā)現(xiàn)了問(wèn)題,只能拋異常;而對(duì)于get方法,hibernate一定要獲取到真實(shí)的數(shù)據(jù),否則返回null。
?。保绻也坏椒蠗l件的紀(jì)錄,get()方法將返回null.而load()將會(huì)報(bào)出ObjectNotFoundEcception.
2.load()方法可以返回實(shí)體的代理類(lèi)實(shí)例,而get()永遠(yuǎn)只返回實(shí)體類(lèi).
3.load()方法可以充分利用二級(jí)緩存和內(nèi)部緩存的現(xiàn)有數(shù)據(jù),而get()方法只在內(nèi)部緩存中進(jìn)行查找,如沒(méi)有發(fā)現(xiàn)對(duì)應(yīng)數(shù)據(jù)將跳過(guò)二級(jí)緩存,直接調(diào)用SQL完成查找.