瘋狂

          STANDING ON THE SHOULDERS OF GIANTS
          posts - 481, comments - 486, trackbacks - 0, articles - 1
            BlogJava :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理

          mappedBy跟JoinColumn/JoinTable .

          Posted on 2011-09-30 14:28 瘋狂 閱讀(6521) 評論(0)  編輯  收藏 所屬分類: hibernate

          對于mappedBy復習下:

          a) 只有OneToOne,OneToMany,ManyToMany上才有mappedBy屬性,ManyToOne不存在該屬性;
          b) mappedBy標簽一定是定義在the owned side(被擁有方的),他指向the owning side(擁有方);
          c) mappedBy的含義,應該理解為,擁有方能夠自動維護 跟被擁有方的關系;
             當然,如果從被擁有方,通過手工強行來維護擁有方的關系也是可以做到的。

          d) mappedBy跟JoinColumn/JoinTable總是處于互斥的一方,可以理解為正是由于擁有方的關聯被擁有方的字段存在,擁有方才擁有了被 擁有方。mappedBy這方定義的JoinColumn/JoinTable總是失效的,不會建立對應的字段或者表

           


          人跟身份證雙向關聯

          在Person 里面定義的注解:

          @OneToOne(cascade={CascadeType.ALL},optional=true)
          public IDCard getIdCard() {
                   return idCard;
          }

          在IDCard 里面定義的注釋:
          @OneToOne(cascade=CascadeType.ALL,mappedBy="idCard" , optional=false)
          public Person getPerson() {
                 return person;
          }
          多了一個mappedBy這個方法,它表示什么呢?它表示當前所在表和Person的關系是定義在Person里面的idCard這個成員上面的,它表示此表是一對一關系中的從表,也就是關系是在person表里面維護的 ,這一點很重要 . Person表是關系的維護者,owner side,有主導權,它有個外鍵指向IDCard。
          我們也可以讓主導權在IDCard上面,也就是讓它產生一個指向Person的外鍵,這也是可以的,但是最好是讓Person來維護整個關系,這樣更符合我們正常的思維 .

          我們也可以看到在Person里面IDCard是注釋是optional=true,也就是說一個人是可以沒有身份證的,但是一個身份證不可以沒有人,所以在IDCard里面注釋person的時候,optional就為false了,這樣就可以防止一個空的身份證記錄進數據庫.

          主站蜘蛛池模板: 南开区| 临桂县| 昌图县| 太原市| 伊金霍洛旗| 新宁县| 莎车县| 汤阴县| 马尔康县| 射阳县| 洱源县| 乌恰县| 通河县| 香河县| 乾安县| 莆田市| 宁都县| 繁峙县| 新巴尔虎右旗| 呈贡县| 临朐县| 海城市| 肃南| 金堂县| 信丰县| 刚察县| 丰顺县| 城步| 安阳市| 泾源县| 梅河口市| 色达县| 桦甸市| 五莲县| 崇左市| 秦皇岛市| 襄城县| 望城县| 夏河县| 综艺| 泰兴市|