問題は次のようになります。
製品テーブル。3
joined-subclasses
:DVD、CD、本。ロールテーブル(複合ID:NAME、ROLE、PRODUCT)、およびディスクリミネーター列によるサブクラスROLE:Actor、Director、Artist、Authorjavaクラスにマップされるactor、director、artist、authorなど。(かなり普通だと思います)..。
本には、著者、CDアーティスト、DVD俳優、監督がいます。これらはすべて、役割のサブクラスである、アイテムのクラス(たとえば、作家、監督、アーティストなど)を指す関係でモデル化されています(2を参照)。。)
set
one-to-many
結合されたサブクラスに(人/ロールの)そのようなセットが1つしかない限り、すべて正常に機能します。しかし、 DVD 、俳優、監督のように2つある場合、HibernateはWrongClassExceptionをスローしますか?
XMLの抜粋(Product.hbm.xml):
<joined-subclass name="media.DVD" table="V_DVD" lazy="false">
<key column="IDPRODUCT"/>
<property column="FORMAT" name="format" type="string"/>
...
<set name="actors" lazy="false">
<key column="IDPRODUCT"/>
<one-to-many class="media.DVD$Actor"/>
</set>
<set name="directors" lazy="false">
<key column="IDPRODUCT"/>
<one-to-many class="media.DVD$Director"/>
</set>
...
</joined-subclass>
XML(Person.hbm.xml):
<class name="media.Person" table="V_ROLE">
<composite-id>
<key-property column="NAME" name="name" type="string"/>
<key-property column="ROLE" name="role" type="string"/>
<key-many-to-one class="media.Product" column="IDPRODUCT"
name="product"/>
</composite-id>
<discriminator column="ROLE" insert="false" type="string"/>
<property name="name"/>
<property name="role"/>
<many-to-one class="media.Product" column="IDPRODUCT"
insert="false" name="product" update="false"/>
<subclass discriminator-value="author" name="media.Book$Author"/>
<subclass discriminator-value="artist" name="media.Music$Artist"/>
<subclass discriminator-value="creator" name="media.DVD$Creator"/>
<subclass discriminator-value="director" name="media.DVD$Director"/>
<subclass discriminator-value="actor" name="media.DVD$Actor"/>
</class>
それは私にはいくぶん大丈夫のようですが、それでも例外をスローします。アイデアありがとうございます!