日韩欧美另类久久久精品_亚洲大色堂人在线无码_国产三级aⅴ在线播放_在线无码aⅴ精品动漫_国产精品精品国产专区

Hibernate 的 10 個常見面試問題及答案

  Hibernate中get和load有什么不同之處?

  把get和load放到一起進行對比是Hibernate面試時最常問到的問題,這是因為只有正確理解get()和load()這二者后才有可能高效地使用Hibernate。get和load的最大區(qū)別是,如果在緩存中沒有找到相應的對象,get將會直接訪問數(shù)據(jù)庫并返回一個完全初始化好的對象,而這個過程有可能會涉及到多個數(shù)據(jù)庫調用;而load方法在緩存中沒有發(fā)現(xiàn)對象的情況下,只會返回一個代理對象,只有在對象getId()之外的其它方法被調用時才會真正去訪問數(shù)據(jù)庫,這樣就能在某些情況下大幅度提高性能。

  Hibernate中save、persist和saveOrUpdate這三個方法的不同之處?

  除了get和load,這又是另外一個經常出現(xiàn)的Hibernate面試問題。 所有這三個方法,也就是save()、saveOrUpdate()和persist()都是用于將對象保存到數(shù)據(jù)庫中的方法,但其中有些細微的差別。例如,save()只能INSERT記錄,但是saveOrUpdate()可以進行 記錄的INSERT和UPDATE。還有,save()的返回值是一個Serializable對象,而persist()方法返回值為void。

  Hibernate中的命名SQL查詢指的是什么?

  Hibernate的這個面試問題同Hibernate提供的查詢功能相關。命名查詢指的是用標簽在影射文檔中定義的SQL查詢,可以通過使用Session.getNamedQuery()方法對它進行調用。命名查詢使你可以使用你所指定的一個名字拿到某個特定的查詢。 Hibernate中的命名查詢可以使用注解來定義,也可以使用我前面提到的xml影射問句來定義。在Hibernate中,@NameQuery用來定義單個的命名查詢,@NameQueries用來定義多個命名查詢。

  Hibernate中的SessionFactory有什么作用? SessionFactory是線程安全的嗎?

  這也是Hibernate框架的常見面試問題。顧名思義,SessionFactory就是一個用于創(chuàng)建Hibernate的Session對象的工廠。SessionFactory通常是在應用啟動時創(chuàng)建好的,應用程序中的代碼用它來獲得Session對象。作為一個單個的數(shù)據(jù)存儲,它也是 線程安全的,所以多個線程可同時使用同一個SessionFactory。Java JEE應用一般只有一個SessionFactory,服務于客戶請求的各線程都通過這個工廠來獲得Hibernate的Session實例,這也是為什么SessionFactory接口的實現(xiàn)必須是線程安全的原因。還有,SessionFactory的內部狀態(tài)包含著同對象關系影射有關的所有元數(shù)據(jù),它是 不可變的,一旦創(chuàng)建好后就不能對其進行修改了。

  Hibernate中的Session指的是什么? 可否將單個的Session在多個線程間進行共享?

  前面的問題問完之后,通常就會接著再問這兩個問題。問完SessionFactory的問題后就該輪到Session了。Session代表著Hibernate所做的一小部分工作,它負責維護者同數(shù)據(jù)庫的鏈接而且 不是線程安全的,也就是說,Hibernage中的Session不能在多個線程間進行共享。雖然Session會以主動滯后的方式獲得數(shù)據(jù)庫連接,但是Session最好還是在用完之后立即將其關閉。

  hibernate中sorted collection和ordered collection有什么不同?

  T這個是你會碰到的所有Hibernate面試問題中比較容易的問題。sorted collection是通過使用 Java的Comparator在內存中進行排序的,ordered collection中的排序用的是數(shù)據(jù)庫的order by子句。對于比較大的數(shù)據(jù)集,為了避免在內存中對它們進行排序而出現(xiàn) Java中的OutOfMemoryError,最好使用ordered collection。

  Hibernate中transient、persistent、detached對象三者之間有什么區(qū)別?

  在Hibernate中,對象具有三種狀態(tài):transient、persistent和detached。同Hibernate的session有關聯(lián)的對象是persistent對象。對這種對象進行的所有修改都會按照事先設定的刷新策略,反映到數(shù)據(jù)庫之中,也即,可以在對象的任何一個屬性發(fā)生改變時自動刷新,也可以通過調用Session.flush()方法顯式地進行刷新。如果一個對象原來同Session有關聯(lián)關系,但當下卻沒有關聯(lián)關系了,這樣的對象就是detached的對象。你可以通過調用任意一個session的update()或者saveOrUpdate()方法,重新將該detached對象同相應的seesion建立關聯(lián)關系。Transient對象指的是新建的持久化類的實例,它還從未同Hibernate的任何Session有過關聯(lián)關系。同樣的,你可以調用persist()或者save()方法,將transient對象變成persistent對象?梢涀,這里所說的transient指的可不是 Java中的transient關鍵字,二者風馬牛不相及。

  Hibernate中Session的lock()方法有什么作用?

  這是一個比較棘手的Hibernate面試問題,因為Session的lock()方法重建了關聯(lián)關系卻并沒有同數(shù)據(jù)庫進行同步和更新。因此,你在使用lock()方法時一定要多加小心。順便說一下,在進行關聯(lián)關系重建時,你可以隨時使用Session的update()方法同數(shù)據(jù)庫進行同步。有時這個問題也可以這么來問:Session的lock()方法和update()方法之間有什么區(qū)別?。這個小節(jié)中的關鍵點也可以拿來回答這個問題。

  Hibernate中二級緩存指的是什么?

  這是同Hibernate的緩存機制相關的第一個面試問題,不出意外后面還會有更多這方面的問題。二級緩存是在SessionFactory這個級別維護的緩存,它能夠通過節(jié)省幾番數(shù)據(jù)庫調用往返來提高性能。還有一點值得注意,二級緩存是針對整個應用而不是某個特定的session的。

  為什么在Hibernate的實體類中要提供一個無參數(shù)的構造器這一點非常重要?

  每個Hibernate實體類必須包含一個 無參數(shù)的構造器, 這是因為Hibernate框架要使用Reflection API,通過調用Class.newInstance()來創(chuàng)建這些實體類的實例。如果在實體類中找不到無參數(shù)的構造器,這個方法就會拋出一個InstantiationException異常。

  可不可以將Hibernate的實體類定義為final類?

  是的,你可以將Hibernate的實體類定義為final類,但這種做法并不好。因為Hibernate會使用代理模式在延遲關聯(lián)的情況下提高性能,如果你把實體類定義成final類之后,因為 Java不允許對final類進行擴展,所以Hibernate就無法再使用代理了,如此一來就限制了使用可以提升性能的手段。不過,如果你的持久化類實現(xiàn)了一個接口而且在該接口中聲明了所有定義于實體類中的所有public的方法輪到話,你就能夠避免出現(xiàn)前面所說的不利后果。

相關導讀:

面試沒有“通關密碼”

2014年公務員面試:膽怯的你,請開口

本文已影響6827
上一篇:農村信用社面試問題匯總 下一篇:OTIS的面試經歷

相關文章推薦

|||||