亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 學院 > 開發設計 > 正文

Java 中的父子關系及 inverse 詳解

2019-11-18 13:16:29
字體:
來源:轉載
供稿:網友

  首先以父子關系為例:
  
  <
  
  對應生成的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 本身不維護表之間的關系!,而由想反的一方 children來維護,
  
  *CASCADE=“ALL”表示 無論是update,insert ,delete 都保持幾連關系
  
  *lazy="true"表示初始化父親的時候不會把所有的兒子都從數據庫中load進來。
  
  下面先看一下幾個例子:
  
  生成的SQL:
  
  代碼:
  Hibernate: insert into PARENT (ID) values (default)
  Hibernate: insert into CHILD (PARENTID, ID) values (?, default)
  Hibernate: insert into CHILD (PARENTID, ID) values (?, default) 
  
  結果 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);就把兩個兒子保存進了數據庫。
  
  *首先講講inverse=true作用: 這里關系是由兒子維護的,所以假如只是往父親里加入兒子,不給兒子設置父親的話session.save(parent),就不會保存兒子! 看這個例子:注重與例子1的對比
  
  代碼:
  *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沒有變
  
  代碼:
  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 
  
  *注重父子關系丟失了 C:/Myapp/SQLLIB/BIN>db2 select * from child
  
  代碼:
  ID     PARENTID
  ----------- -----------
       74      -
       75      -
       76     45
  C:/Myapp/SQLLIB/BIN>db2 select * from parent
   
  ID
  -----------
       45 
  
  *為什么最后一個孩子的父親沒有丟失呢? 就在于child3.setParent(parent);,所以關系是由孩子維護的,假如child不setParent,或者 new childPO(父親)的話 父子關系就丟失了,parent.setChildren(list);是沒有用的!
  *這里就又引入了另外一個問題為什么要用inverse? 用了它維護關系起豈不是很麻煩?,這里給出個例子給大家一個解釋:(要害原因在于性能)
  
  下面這個例子和例子一完全一樣,所差的就是沒有用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() 
  
  結果 C:/Myapp/SQLLIB/BIN>db2 select * from parent
  
  代碼:
  ID
  -----------
       46
  ID     PARENTID
  ----------- -----------
       77     46
       78     46
       79     46 
  
  明顯比原來多了一句Hibernate: update CHILD set PARENTID=? where ID=?針對每一個孩子都去更新父親的id明顯速度很慢,因為父親有個孩子的集合,他無法知道哪個孩子的父親id已經指向自己了,所以對于每一個孩子,都要更新父親使他只想自己,而這個關系由孩子維護就好多了,每個孩子只有一個父親,只有設置過的才需要更新,所以顯然,這個父子關系由孩子來維護比較省力.減輕了數據庫的負擔
  
  *現在我們再來看看在沒有 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

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产成人精品视| 国产精品亚洲美女av网站| 91夜夜揉人人捏人人添红杏| 北条麻妃99精品青青久久| 国内外成人免费激情在线视频| 欧美野外wwwxxx| 亚洲美女av黄| 一本色道久久88亚洲综合88| 久久精品电影网站| 日本久久久久亚洲中字幕| 国产精品一区久久久| 国产亚洲精品久久久优势| 亚洲香蕉伊综合在人在线视看| 国产精品一区二区三区免费视频| 国产精品久久久久久久久| 亚洲片av在线| 久久久精品在线观看| 亚洲自拍欧美色图| 精品国产依人香蕉在线精品| 欧美日韩一区二区免费视频| 久久久久久欧美| 国产日产欧美a一级在线| 久久精品国产亚洲7777| 成人福利网站在线观看11| 在线观看亚洲区| 国产精品午夜国产小视频| 色悠久久久久综合先锋影音下载| 欧美亚洲免费电影| 久久成人国产精品| 久久久久这里只有精品| 成人精品网站在线观看| 992tv成人免费视频| 69久久夜色精品国产69乱青草| 一区二区三区久久精品| 国产91久久婷婷一区二区| 国产精品精品一区二区三区午夜版| 精品激情国产视频| 日韩欧美福利视频| 欧美午夜片欧美片在线观看| 一区二区三区亚洲| 国产精品女人久久久久久| 9.1国产丝袜在线观看| 91av视频在线免费观看| 国产精品午夜一区二区欲梦| 欧美福利视频在线观看| 久久夜色撩人精品| 91网在线免费观看| 亚洲人永久免费| 成人av资源在线播放| 国产区精品在线观看| 九九精品在线观看| 日韩av免费一区| 视频一区视频二区国产精品| 欧美精品videosex牲欧美| 欧美大码xxxx| 亚洲一级黄色av| 久久国产精品99国产精| 国产视频观看一区| 亚洲天堂精品在线| 亚洲xxxx3d| 成人信息集中地欧美| 91精品国产91| 欧美视频免费在线观看| 成人久久久久爱| 国产精品99蜜臀久久不卡二区| 欧美日韩爱爱视频| 欧美电影免费观看网站| 精品国产91乱高清在线观看| 国产精品99久久久久久人| 亚洲国产精品免费| 好吊成人免视频| 欧美一级淫片aaaaaaa视频| 中文亚洲视频在线| 高潮白浆女日韩av免费看| 欧美电影《睫毛膏》| 成人久久久久爱| 日韩激情第一页| 国产成人精彩在线视频九色| 18一19gay欧美视频网站| 国产一区二区三区高清在线观看| 国产精品第一第二| 国产成人jvid在线播放| 一区二区三区天堂av| 国产精品美乳在线观看| 亚洲一级黄色片| 免费不卡在线观看av| 日韩av在线网址| 日韩免费观看在线观看| 亚洲a∨日韩av高清在线观看| 日韩精品在线观看一区| 日本一区二区三区四区视频| 亚洲午夜久久久久久久| y97精品国产97久久久久久| 亚洲欧美日韩直播| 一区二区三区四区精品| 国产一区视频在线播放| 国产视频福利一区| 中文字幕亚洲综合| 亚洲精品www久久久久久广东| 国产精品高精视频免费| 欧美成人在线影院| 欧美专区国产专区| 亚洲成人1234| 欧美一级电影免费在线观看| 成人福利网站在线观看| 亚洲国产第一页| 人体精品一二三区| 亚洲香蕉av在线一区二区三区| 日本一区二区三区四区视频| 国产+成+人+亚洲欧洲| 一区二区亚洲精品国产| 日韩精品视频免费在线观看| 日韩在线观看免费| 尤物精品国产第一福利三区| 欧美一区二区色| 精品偷拍各种wc美女嘘嘘| 亚洲人成绝费网站色www| 久久影视电视剧凤归四时歌| 日韩精品在线看| 伊人一区二区三区久久精品| 国产一区香蕉久久| 亚洲国产精品久久久| 欧美午夜视频在线观看| 国产剧情久久久久久| 亚洲天堂网站在线观看视频| 九九综合九九综合| 日韩av在线网址| 午夜免费在线观看精品视频| 91精品国产电影| 国产成人精品最新| 高清欧美性猛交xxxx黑人猛交| 国产成人一区二区三区小说| 搡老女人一区二区三区视频tv| 亚洲一区二区三区四区在线播放| 亚洲色图综合久久| 欧美劲爆第一页| 欧美激情一级精品国产| 26uuu日韩精品一区二区| 日本久久久久久久久| 亚洲午夜小视频| 欧美视频13p| 美女扒开尿口让男人操亚洲视频网站| 亚洲最大在线视频| 久久99精品久久久久久琪琪| 亚洲最新av在线网站| 黑人狂躁日本妞一区二区三区| 国产成人免费av电影| 91啪国产在线| 亚洲国产天堂久久国产91| 亚洲在线免费视频| 欧美激情va永久在线播放| 亚洲成人精品久久| 亚洲国产精品嫩草影院久久| 精品久久久一区二区| 亚洲大胆美女视频| 午夜免费久久久久| 欧美日本国产在线| 日韩欧美第一页| 国产精品狼人色视频一区| 日韩电影免费在线观看| 久久亚洲精品国产亚洲老地址| 91九色视频导航| 日本久久亚洲电影| 欧美性猛交xxxx乱大交3|