だからここに私の問題があります。私はこれらの 2 つのテーブルを持っていますが、これらは単独でうまくマップされます。無関係なので削除した追加フィールドがいくつかあります。アイテムの所有者のために、Item と ItemAdminScrtyGrp の間の 1 対 1 のマッピングが必要です。アイテムの所有者を取得するために使用する 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';
ご協力いただきありがとうございます。