1

所以这是我的问题。我有这两张表,它们自己映射得很好。我删除了一些附加字段,因为它们无关紧要。我需要在 Item 和 ItemAdminScrtyGrp 之间为项目的所有者进行一对一的映射。我已经包含了用于获取项目所有者的 SQL。更改数据库架构不是一种选择。有什么想法可以将复合键的一部分和映射的非主属性结合起来吗?

休眠映射

<hibernate-mapping>
<class name="Item">
    <composite-id class="ItemKey" name="itemKey" >
        <key-property name="itemId" column="ITEM_ID" />
        <key-property name="revision" column="RVSN_ID" />
    </composite-id>
</class>
<class name="ItemAdminScrtyGrp">
    <composite-id name="key" class="ItemAdminScrtyGrpKey" >
        <key-property name="securityProfileCode" column="SCRTY_PROF_CD" />
        <key-property name="itemId" column="ITEM_ID" />
        <key-property name="revision" column="RVSN_ID" />
    </composite-id>
    <property name="securityLevelCode" column="SCRTY_LVL_TYP_CD" />
    <property name="ownerFlag" column="OWNR_FLG"/>
</class>
</hibernate-mapping>

SQL

select SCRTY_PROF_CD from ItemAdminScrtyGrp grp
join Item 
on grp.ITEM_ID = Item.ITEM_ID and 
   grp.RVSN_ID = Item.RVSN_ID and 
   grp.OWNR_FLG = 'y'
where Item.ITEM_ID = 'abc' and Item.RVSN_ID = '123';

感谢您的任何帮助,您可以提供。

4

1 回答 1

0

这种映射似乎存在缺陷。请参阅https://hibernate.atlassian.net/browse/HHH-4939

于 2013-11-11T13:53:37.073 回答