成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

Hibernate配置要點詳談

開發 后端
本文一共介紹了27點Hibernate的配置要點,繼續了解請看下文。

1.兩種配置文件:

A.hibernate.cfg.xml和B.hibernate.properties

A中可含映射文件的配置,而B中hard codes加映射文件。

A.Configuration config=new Configuration().config();

B.Configuration config=new Configuration();

config.addClass(TUser.class);

2.你不必一定用hibernate.cfg.xml或hibernate.properties這兩文件名,你也不一定非得把配置文件放在Classes下,

  1. File file=new File("c://sample//myhibernate.xml");  
  2. Configuration config=new Configuration().config(file);  

3. session.Flush() 強制數據庫立即同步,當用事務時,不必用flush,事務提交自動調用flush在session關閉時也會調用flush

4. Hibernate總是使用對象類型作為字段類型

5. XDoclet專門建立了hibernate doclet,就是在java代碼上加上一些java docTag,后來再讓XDoclet分析該java代碼,生成映射文件;

6.HQL子句本身大小寫無關,但是其中出現的類名和屬性名必須注意大小寫區分。

7.關系:Constrained:約束,表明主控表的主鍵上是否存在一個外鍵(foreigh key)對其進行約束。

property-ref:關聯類中用于與主控類相關聯的屬性名,默認為關聯類的主鍵屬性名

單向一對多需在一方配置,雙向一對多需在雙方進行配置

8.lazy=false:被動方的記錄由hibernate負責記取,之后存放在主控方指定的Collection類型屬性中

9. java.util.Set或net.sof.hibernate.collecton.Bag類型的Collection

10.重要:inverse:用于標識雙向關聯中的被動方一端。

inverse=false的一方(主控方)負責維護關聯關系.默認值:false

11.batch-size:采用延遲加載特征時,一次讀入的數據數昨。

12.一對多通過主控方更新(主控方為一方時)

  1. user.getAddresses().add(addr); session.save(user);//通過主控對象級聯更新 

13.在one-to-many 關系中,將many 一方設為主動方(inverse=false)將有助性能的改善。在一方設置關系時,inverse=true,即將主控權交給多方,  這樣多方可主動從一方獲得foreign key,然后一次insert即可完工。

  1. addr.setUser(user);//設置關聯的TUser對象   
  2. user.getAddresses().add(addr);  
  3. session.save(user);//級聯更新 

14.只有設為主控方的一方才關心(訪問)對方的屬性,被動方是不關心對方的屬性的。

15.one-to-many與many-to-one節點的配置屬性不同:

一對多關系多了lazy和inverse兩個屬性多對多節點屬性:

column:中間映射表中,關聯目標表的關聯字段

class:類名,關聯目標類

outer-join:是否使用外聯接

注意:access是設置屬性值的讀取方式。

column是設置關聯字段。

16.多對多,注意兩方都要設置inverse和lazy,cascade只能設為insert-update

多對多關系中,由于關聯關系是兩張表相互引用,因此在保存關系狀態時必須對雙方同時保存。

  1. group1.getRoles().add(role1);  
  2.  
  3. role1.getGroups().add(group1);   
  4.  
  5. session.save(role1);  
  6.  
  7. session.save(group1);  

17.關于vo和po

vo經過hibernate容量處理,就變成了po(該vo的引用將被容器保存,并且在session關閉時flush,因此po如果再傳到其它地方改變了,就危險了)    vo和po相互轉換:BeanUtils.copyProperties(anotherUser,user);

18.對于save操作而言,如果對象已經與Session相關聯(即已經被加入Session的實體容器中),則無需進行具體的操作。因為之后的Session.flush過程中,Hibernate 會對此實體容器中的對象進行遍歷,查找出發生變化的實體,生成并執行相應的update 語句。

19.如果我們采用了延遲加載機制,但希望在一些情況下,實現非延遲加 載時的功能,也就是說,我們希望在Session關閉后,依然允許操作user的addresses 屬性 Hibernate.initialize方法可以通過強制加載關聯對象實現這一功能: 這也正是我們為什么在編寫POJO時,必須用JDK Collection接口(如Set,Map), 而非特定的JDK Collection實現類(如HashSet、HashMap)申明Collection屬性的 原因。

20.事務:從sessionFactory獲得session,其自動提交屬性就已經關閉(AutoCommit=false),此時若執行了jdbc操作,如果不顯式調用session.BeginTransaction(),是不會執行事務操作的。

jdbc transaction:基于同一個session(就是同一個connection)的事務;

jta transaction:跨session(跨connection)事務.

對于jta事務,有三種實現方法:

A、

  1. UserTransaction tx=new InitialContext().lookup("...");   
  2. tx.commit();  

B、使用hibernate封裝的方法:(不推薦)

  1. Transaction tx=session.beginTransaction();   
  2. tx.commit();  

C、使用ejb之sessionBean的事務技持方法,你只要在把需要在發布描述符中,把需要jta事務的方法聲明為require即可

21.悲觀鎖,樂觀鎖:

樂觀鎖一般通過version來實現,注意version節點必須出現在id后。

22.Hibernate中,可以通過Criteria.setFirstResult和Criteria.setFetchSize方法設定分頁范圍。

Query接口中也提供了與其一致的方法,hibernate主要在dialect類中實現在這個功能。

23.

  1. cache   
  2. ……   
  3. net.sf.ehcache.hibernate.Provider  

還需對ecache本身進配置

之后在映射文件中指定各個映射實體的cache策略

....

*****************************************************

Query.list()跟Query.iterate()的不同: 對于query.list()總是通過一條sql語句獲取所有記錄,然后將其讀出,填入pojo返回; 但是query.iterate(),則是首先通過一條Select SQL 獲取所有符合查詢條件的記錄的 id,再對這個id 集合進行循環操作,通過單獨的Select SQL 取出每個id 所對應的記 錄,之后填入POJO中返回。

也就是說,對于list 操作,需要一條SQL 完成。而對于iterate 操作,需要n+1 條SQL。list方法將不會從Cache中讀取數據。iterator卻會。

24.ThreadLocal:它會為每個線程維護一個私有的變量空間。實際上, 其實現原理是在JVM 中維護一個Map,這個Map的key 就是當前的線程對象,而value則是 線程通過ThreadLocal.set方法保存的對象實例。當線程調用ThreadLocal.get方法時, ThreadLocal會根據當前線程對象的引用,取出Map中對應的對象返回。

這樣,ThreadLocal通過以各個線程對象的引用作為區分,從而將不同線程的變量隔離開來。

25.Hibernate官方開發手冊標準示例:

  1. public class HibernateUtil {   
  2. private static SessionFactory sessionFactory;   
  3. static {   
  4. try {  
  5. // Create the SessionFactory sessionFactory =  
  6. new Configuration().configure().buildSessionFactory();  
  7.  } catch (HibernateException ex)  
  8. {  
  9. throw new RuntimeException( "Configuration problem: " + ex.getMessage(), ex );  
  10.  }  
  11.  }  
  12. public static final ThreadLocal session = new ThreadLocal();  
  13. public static Session currentSession() throws HibernateException {  
  14. Session s = (Session) session.get();   
  15. // Open a new Session, if this Thread has none yet if (s == null) {  
  16. s = sessionFactory.openSession(); session.set(s);  
  17. }  
  18. return s;   
  19. }   
  20. public static void closeSession() throws HibernateException  
  21. {  
  22. Session s = (Session) session.get();  
  23. session.set(null);  
  24. if (s != null) s.close();  
  25. }  

26.通過filter實現session的重用:

  1. public class PersistenceFilter implements Filter {  
  2. protected static ThreadLocal hibernateHolder = new ThreadLocal();  
  3. public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain)  
  4. throws IOException, ServletException{  
  5. hibernateHolder.set(getSession());  
  6. try {  
  7. ……  
  8. chain.doFilter(request, response);  
  9. ……  
  10. }  
  11. finally {  
  12. Session sess = (Session)hibernateHolder.get();  
  13. if (sess != null) {  
  14. hibernateHolder.set(null);  
  15. try {  
  16. sess.close();  
  17. }  
  18. catch (HibernateException ex) {  
  19. throw new ServletException(ex);  
  20. }  
  21. }  
  22. }  
  23. }  
  24. ……  

27.Spring的參數化事務管理功能相當強大,筆者建議在基于Spring Framework的應用 開發中,盡量使用容器管理事務,以獲得數據邏輯代碼的***可讀性。

  1. public class UserDAO extends HibernateDaoSupport implements IUserDAO {  
  2. public void insertUser(User user){  
  3. getHibernateTemplate().saveOrUpdate(user);  
  4. }  

上面的UserDAO實現了自定義的IUserDAO接口,并擴展了抽象類:

HibernateDaoSupport HibernateSupport實現了HibernateTemplate和SessionFactory實例的關聯。

HibernateTemplate對Hibernate Session操作進行了封裝,而 HibernateTemplate.execute方法則是一封裝機制的核心

*在spring的配置文件里,移植了整個hibernate.cfg.xml的內容。

原文鏈接:http://blog.csdn.net/ysynlm/article/details/2766614

【編輯推薦】

  1. Hibernate配置文件和映射元素解釋
  2. 詳解Hibernate攔截器與事件監聽器
  3. Hibernate的緩存解讀
  4. Hibernate的集合映射
  5. Hibernate關聯關系配置
責任編輯:林師授 來源: ysynlm的博客
相關推薦

2015-05-05 11:06:02

JavaJava框架Struts+Hibe

2009-06-26 16:09:21

Hibernate查詢HQL

2012-02-03 10:54:50

HibernateJava

2009-11-17 15:13:28

PHP數組

2011-05-17 14:29:29

Dijkstra

2009-09-22 15:04:37

Hibernate M

2009-09-27 14:24:10

Hibernate配置

2009-09-22 10:23:15

Hibernate配置

2009-09-23 14:00:07

Hibernate連接

2009-09-24 15:03:30

Hibernate配置

2016-12-15 08:38:50

1 Hibernate基本配置

2013-01-04 13:22:42

OpenFlowSDN

2009-11-19 11:12:13

Oracle LogM

2009-09-27 13:25:22

2009-09-29 17:29:43

Hibernate S

2009-06-17 16:22:45

Hibernate連接

2009-09-29 15:52:26

Hibernate X

2009-09-22 14:44:18

Hibernate.c

2009-06-29 08:50:20

Hibernate主鍵

2009-09-22 16:04:50

Hibernate連接
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 亚洲国产中文字幕 | 一区二区三| 精品久久香蕉国产线看观看亚洲 | 亚洲精品9999久久久久 | 999久久久免费精品国产 | 国产精品免费观看 | 日本涩涩视频 | 国产韩国精品一区二区三区 | 日日操日日干 | 天天操网 | 欧美激情在线精品一区二区三区 | 九九av | 久久久久久久久久影视 | 91精品国产91久久综合桃花 | 九九精品久久久 | 日韩成人在线观看 | 国产男人的天堂 | 欧美日韩国产高清 | 久久99蜜桃综合影院免费观看 | 日韩欧美国产一区二区三区 | 婷婷丁香综合网 | 日韩在线一区二区三区 | 国产一级片网站 | 亚洲性爰| 一级黄在线观看 | 99精品久久 | 国产成人在线一区 | 久久久久久久久毛片 | 成人国产精品免费观看视频 | 久久精品久久久久久 | 日韩一区二区三区视频 | 日批日韩在线观看 | 精品美女视频在免费观看 | 欧美在线视频网站 | 久久久精品网站 | 久久三级av | 欧美三区 | 国产精品久久久久久久久久久久久 | 天天干夜夜| 日韩免费一区 | 精品欧美一区二区精品久久 |