<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    jinfeng_wang

    G-G-S,D-D-U!

    BlogJava 首頁 新隨筆 聯(lián)系 聚合 管理
      400 Posts :: 0 Stories :: 296 Comments :: 0 Trackbacks

    Mapping collections of value types (from 《hibernate in action》chapter 6)

     

    這里所舉的例子,都是基于這樣的一個(gè)情景,Item中包含有Images

    <set name="images" lazy="true" table="ITEM_IMAGE">

    <key column="ITEM_ID"/>

    <element type="string" column="FILENAME" not-null="true"/>

    </set>

    這里的<key>定義了外鍵ITEM_ID,<elememt>則聲明了集合的內(nèi)部數(shù)據(jù)元素。<set>定義的集合中不可以有重復(fù)的數(shù)據(jù)。

     

    <idbag name="images" lazy="true" table="ITEM_IMAGE">

    <collection-id type="long" column="ITEM_IMAGE_ID">

    <generator class="sequence"/>

    </collection-id>

    <key column="ITEM_ID"/>

    <element type="string" column="FILENAME" not-null="true"/>

    </idbag>

    ITEM_IMAGE_ID為主鍵,而ITEM_ID則為外鍵,<element>元素不變,這就允許集合中的數(shù)據(jù)重復(fù)。

     

    <list name="images" lazy="true" table="ITEM_IMAGE">

    <key column="ITEM_ID"/>

    <index column="POSITION"/>

    <element type="string" column="FILENAME" not-null="true"/>

    </list>

    這里為ITEM_IMAGE表添加了index,整個(gè)表的主鍵是ITEM_IDPOSITION構(gòu)成的復(fù)合主鍵,它允許集合中的數(shù)據(jù)根據(jù)POSITION進(jìn)行排序。

     

    <map name="images"

    lazy="true"

    table="ITEM_IMAGE"

    sort="natural">

    <key column="ITEM_ID"/>

    <index column="IMAGE_NAME" type="string"/>

    <element type="string" column="FILENAME" not-null="true"/>

    </map>

    這里為ITEM_IMAGE表添加了index,整個(gè)表的主鍵是ITEM_IDPOSITION構(gòu)成的復(fù)合主鍵,它允許集合中的數(shù)據(jù)根據(jù)sort指定的內(nèi)容進(jìn)行排序,這里允許用戶對(duì)sort進(jìn)行定制。

     

    <map name="images"

    lazy="true"

    table="ITEM_IMAGE"

    order-by="IMAGE_NAME asc">

    <key column="ITEM_ID"/>

    <index column="IMAGE_NAME" type="string"/>

    <element type="string" column="FILENAME" not-null="true"/>

    </map>

    這里采用的是orbder-by,注意sortorder-by的區(qū)別。Sort是在內(nèi)存中使用comparator進(jìn)行排序,而order-by則是在數(shù)據(jù)庫(kù)中使用SQL語句進(jìn)行排序。

     

    <set name="images"

    lazy="true"

    table="ITEM_IMAGE"

    order-by="IMAGE_NAME asc">

    <key column="ITEM_ID"/>

    <composite-element class="Image">

    <property name="name" column="IMAGE_NAME" not-null="true"/>

    <property name="filename" column="FILENAME" not-null="true"/>

    <property name="sizeX" column="SIZEX" not-null="true"/>

    <property name="sizeY" column="SIZEY" not-null="true"/>

    </composite-element>

    </set>

    這里定義了一個(gè)新的Image類,它不是實(shí)體類(entity class),而是一個(gè)簡(jiǎn)單的值類型(value type),僅僅是父實(shí)體的一個(gè)component,其生命周期完全由包含其的父實(shí)體 (parent entity) ITEM控制。這里Image類中包含有數(shù)據(jù)ITEM_ID、 IMAGE_NAME、FILENAME、SIZEX、和SIZEY。

     

     

    <set name="images"

    lazy="true"

    table="ITEM_IMAGE"

    order-by="IMAGE_NAME asc">

    <key column="ITEM_ID"/>

    <composite-element class="Image">

    <parent name="item"/>

    <property name="name" column="IMAGE_NAME" not-null="true"/>

    <property name="filename" column="FILENAME" not-null="true"/>

    <property name="sizeX" column="SIZEX" not-null="true"/>

    <property name="sizeY" column="SIZEY" not-null="true"/>

    </composite-element>

    </set>

    前面定義的IMAGE類中,并不包含有對(duì)父實(shí)體ITEM的引用。也就是說,只可以從ITEM中導(dǎo)航到IMAGE中,但是在IMAGE無法得到ITEM。這可以通過<parent>實(shí)現(xiàn)。這樣IMAGE類中就含有一個(gè)數(shù)據(jù)成員item,指向其父實(shí)體。

    但是,它是無法做到真正的雙向?qū)Ш降?。例如:通過SQL查詢直接得到IMAGE后,但是如同普通的值類型一樣,IMAGE對(duì)象的itemnull,你無法從component如此直接得到其父對(duì)象,這必須由通過父-子關(guān)系的entity完成。

    posted on 2005-04-11 14:12 jinfeng_wang 閱讀(759) 評(píng)論(0)  編輯  收藏 所屬分類: hibernate 、ZZ
    主站蜘蛛池模板: 亚洲AV永久无码精品| 亚洲国产一区视频| 亚洲丰满熟女一区二区v| 无码A级毛片免费视频内谢| 久久亚洲国产视频| 在线观看免费av网站| 亚洲熟妇色自偷自拍另类| 成人午夜免费福利视频| 亚洲影视自拍揄拍愉拍| 国内免费高清在线观看| 亚洲av无码专区在线电影天堂| 四虎www免费人成| 羞羞视频在线观看免费| 国产综合亚洲专区在线| 男人进去女人爽免费视频国产| 337p日本欧洲亚洲大胆艺术| 100000免费啪啪18免进| 亚洲欧美一区二区三区日产| 亚洲?v无码国产在丝袜线观看 | 一级视频免费观看| 亚洲精品~无码抽插| 99久久精品免费精品国产| 亚洲jjzzjjzz在线播放| 国产免费观看网站| 3344在线看片免费| wwwxxx亚洲| 亚洲成?v人片天堂网无码| 精品视频一区二区三区免费| 亚洲小说图片视频| 无码欧精品亚洲日韩一区夜夜嗨 | 亚洲免费在线视频| 亚洲啪AV永久无码精品放毛片| 免费一级毛片在播放视频| a毛片免费在线观看| 国产成+人+综合+亚洲专| 久久亚洲中文字幕精品一区四 | 国产成人啪精品视频免费网| 大地影院MV在线观看视频免费| 亚洲国产视频网站| 国产gv天堂亚洲国产gv刚刚碰| 国内精自视频品线六区免费|