麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁(yè) > 學(xué)院 > 開發(fā)設(shè)計(jì) > 正文

Java 中的父子關(guān)系及 inverse 詳解

2019-11-18 13:16:29
字體:
來(lái)源:轉(zhuǎn)載
供稿:網(wǎng)友

  首先以父子關(guān)系為例:
  
  <
  
  對(duì)應(yīng)生成的DDL drop table PARENT;
  代碼:
  drop table CHILD;
  create table PARENT (ID INTEGER not null generated by default as identity, PRimary key (ID));
  create table CHILD (ID INTEGER not null generated by default as identity, PARENTID INTEGER, primary key (ID));
  alter table CHILD add constraint FK3D1FCFC74B18345 foreign key (PARENTID) references PARENT; 
  
  *大寫的部分inverse="true"表示 ParentPO 本身不維護(hù)表之間的關(guān)系!,而由想反的一方 children來(lái)維護(hù),
  
  *CASCADE=“ALL”表示 無(wú)論是update,insert ,delete 都保持幾連關(guān)系
  
  *lazy="true"表示初始化父親的時(shí)候不會(huì)把所有的兒子都從數(shù)據(jù)庫(kù)中l(wèi)oad進(jìn)來(lái)。
  
  下面先看一下幾個(gè)例子:
  
  生成的SQL:
  
  代碼:
  Hibernate: insert into PARENT (ID) values (default)
  Hibernate: insert into CHILD (PARENTID, ID) values (?, default)
  Hibernate: insert into CHILD (PARENTID, ID) values (?, default) 
  
  結(jié)果 C:/Myapp/SQLLIB/BIN>db2 select * from child
  
  代碼:
  ID     PARENTID
  ----------- -----------
       71     44
       72     44
       73     44
  C:/Myapp/SQLLIB/BIN>db2 select * from parent
   
  ID
  -----------
       44
   
  注重之只有一句:session.save(parent);就把兩個(gè)兒子保存進(jìn)了數(shù)據(jù)庫(kù)。
  
  *首先講講inverse=true作用: 這里關(guān)系是由兒子維護(hù)的,所以假如只是往父親里加入兒子,不給兒子設(shè)置父親的話session.save(parent),就不會(huì)保存兒子! 看這個(gè)例子:注重與例子1的對(duì)比
  
  代碼:
  *ChildPO child = new ChildPO(parent)---〉ChildPO child = new ChildPO(),
  
          ITxMgr tx = null;
          tx = HibernateTxMgr.beginTrans("Add a new relationsh          session = (Session) tx.getSession();
          parent = new ParentPO();
          ChildPO child = new ChildPO();
          ChildPO child2 = new ChildPO();
          List list = new ArrayList();
          list.add(child);
          list.add(child2);
          parent.setChildren(list);
          session.save(parent);
          session.flush();
          System.out.println("dddddddddddddddddddddddddddddddddddddddddddddddddddddd") ;
          ChildPO child3 = new ChildPO();
          child3.setParent(parent);
          session.save(child3);
          session.flush();
          System.out.println("eeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeee") ;
          tx.endTrans(); 
  
  生成的SQL沒(méi)有變
  
  代碼:
  Hibernate: insert into PARENT (ID) values (default)
   
  Hibernate: insert into CHILD (PARENTID, ID) values (?, default)
   
  Hibernate: insert into CHILD (PARENTID, ID) values (?, default)
   
  dddddddddddddddddddddddddddddddddddddddddddddddddddddd
  Hibernate: insert into CHILD (PARENTID, ID) values (?, default)
  eeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeee 
  
  *注重父子關(guān)系丟失了 C:/Myapp/SQLLIB/BIN>db2 select * from child
  
  代碼:
  ID     PARENTID
  ----------- -----------
       74      -
       75      -
       76     45
  C:/Myapp/SQLLIB/BIN>db2 select * from parent
   
  ID
  -----------
       45 
  
  *為什么最后一個(gè)孩子的父親沒(méi)有丟失呢? 就在于child3.setParent(parent);,所以關(guān)系是由孩子維護(hù)的,假如child不setParent,或者 new childPO(父親)的話 父子關(guān)系就丟失了,parent.setChildren(list);是沒(méi)有用的!
  *這里就又引入了另外一個(gè)問(wèn)題為什么要用inverse? 用了它維護(hù)關(guān)系起豈不是很麻煩?,這里給出個(gè)例子給大家一個(gè)解釋:(要害原因在于性能)
  
  下面這個(gè)例子和例子一完全一樣,所差的就是沒(méi)有用inverse=true
  
  例子2:
  
  代碼:
  hibernate-mapping>
    <class name="com.etech.bm.po.ChildPO" table="CHILD">
          <id name="id" column="ID" type="integer">
              <generator class="identity"/>
          </id>
      <many-to-one name="parent" class="com.etech.bm.po.ParentPO" column="PARENTID"/>
    </class>
    <class name="com.etech.bm.po.ParentPO" table="PARENT">
          <id name="id" column="ID" type="integer">
              <generator class="identity"/>
          </id>
      <bag name="children" CASCADE=“ALL”>
          <key column="PARENTID"/>
          <one-to-many class="com.etech.bm.po.ChildPO"/>
      </bag>
    </class>
   
  </hibernate-mapping> 
  
  代碼:
  drop table PARENT;
  drop table CHILD;
  create table PARENT (ID INTEGER not null generated by default as identity, primary key (ID));
  create table CHILD (ID INTEGER not null generated by default as identity, PARENTID INTEGER, primary key (ID));
  alter table CHILD add constraint FK3D1FCFC74B18345 foreign key (PARENTID) references PARENT; 
  
  代碼:
  ITxMgr tx = null;
          tx = HibernateTxMgr.beginTrans("Add a new relationships...");
          session = (Session) tx.getSession();
          parent = new ParentPO();
          ChildPO child = new ChildPO(parent);
          ChildPO child2 = new ChildPO(parent);
          List list = new ArrayList();
          list.add(child);
          list.add(child2);
          parent.setChildren(list);
          session.save(parent);
          session.flush();
          System.out.println("dddddddddddddddddddddddddddddddddddddddddddddddddddddd") ;
          ChildPO child3 = new ChildPO();
          child3.setParent(parent);
          session.save(child3);
          session.flush();
          System.out.println("eeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeee") ;
          tx.endTrans();  
  
  hibernate 生成的sql Hibernate: insert into PARENT (ID) values (default)
  
  代碼:
  Hibernate: insert into CHILD (PARENTID, ID) values (?, default)
   
  Hibernate: insert into CHILD (PARENTID, ID) values (?, default)
   
  Hibernate: update CHILD set PARENTID=? where ID=?
  dddddddddddddddddddddddddddddddddddddddddddddddddddddd
  Hibernate: insert into CHILD (PARENTID, ID) values (?, default)
  Hibernate: values IDENTITY_VAL_LOCAL() 
  
  結(jié)果 C:/Myapp/SQLLIB/BIN>db2 select * from parent
  
  代碼:
  ID
  -----------
       46
  ID     PARENTID
  ----------- -----------
       77     46
       78     46
       79     46 
  
  明顯比原來(lái)多了一句Hibernate: update CHILD set PARENTID=? where ID=?針對(duì)每一個(gè)孩子都去更新父親的id明顯速度很慢,因?yàn)楦赣H有個(gè)孩子的集合,他無(wú)法知道哪個(gè)孩子的父親id已經(jīng)指向自己了,所以對(duì)于每一個(gè)孩子,都要更新父親使他只想自己,而這個(gè)關(guān)系由孩子維護(hù)就好多了,每個(gè)孩子只有一個(gè)父親,只有設(shè)置過(guò)的才需要更新,所以顯然,這個(gè)父子關(guān)系由孩子來(lái)維護(hù)比較省力.減輕了數(shù)據(jù)庫(kù)的負(fù)擔(dān)
  
  *現(xiàn)在我們?cè)賮?lái)看看在沒(méi)有 inverse=true 的條件下 ChildPO child = new ChildPO(parent)---〉ChildPO child = new ChildPO(),
  
  
  代碼:
  ITxMgr tx = null;
          tx = HibernateTxMgr.beginTrans("Add a new relationships...");
          session = (Session) tx.getS

發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 亚洲va久久久噜噜噜久牛牛影视 | 日本成人在线播放 | 久久久久久久久淑女av国产精品 | 精品乱码久久久久 | 国产精品成人一区二区三区吃奶 | 成人男女啪啪免费观看网站四虎 | 18欧美性xxxx极品hd | 午夜视频色 | 亚洲电影在线播放 | 麻豆自拍偷拍视频 | 激情91| 特片网久久 | 免费观看国产精品视频 | 午夜天堂在线视频 | 国产精品野外av久久久 | 成人短视频在线观看 | 鲁人人人鲁人人鲁精品 | 免看黄大片aa | 欧美a视频在线观看 | 国产一级一级片 | 美女视频黄视大全视频免费网址 | h视频免费在线观看 | 九色p| 国产91丝袜在线播放 | 91成人影库| 精品成人久久久 | 国产亚洲精久久久久久蜜臀 | 嫩呦国产一区二区三区av | 国产视频精品在线 | 久久亚洲国产精品 | 欧美男女爱爱视频 | 法国极品成人h版 | videos高潮| 一级毛片在线看 | 天天色宗合 | 中文字幕综合在线观看 | 欧洲精品久久 | 日韩一级片| 色网站在线免费观看 | 午夜视频久久久 | 性视频久久 |