0

问题看起来像这样:

  1. 产品表。3 joined-subclassesDVDCD书籍

  2. 一个Role表(复合 id:NAME、ROLE、PRODUCT),以及按鉴别列 ROLE 的子类:actor、director、artist、author 等。它们映射到 Actor、Director、Artist、Author java 类;(我猜很平常)...

  3. 本书有作者、CD艺术家、DVD演员和导演——这些都是通过指向项目类的关系建模的,例如作者、导演、艺术家等。它们只是角色的子类(见set2 one-to-many.)

只要加入的子类只有一个这样的集合(人员/角色),一切正常。但是当它有两个,比如DVD,演员和导演时,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>

对我来说似乎还可以,但它会引发异常。谢谢你的任何想法!

4

2 回答 2

0

我不得不说,这是一个相当深奥的映射。为什么要使用复合键(鉴别器也是其中的一部分)而不是代理?

这里一个可能的问题是您可能手动将鉴别器值(通过role属性)设置为给定子类应该设置的值。Hibernate 将无法覆盖它(鉴别器映射为 insert="false"),这将导致后续选择时出现 WrongClassException。

也有可能在Productmedia.DVD 扩展的映射中发生了一些奇怪的事情,而您没有包含这些内容。您可以添加它并提供完整的堆栈跟踪吗?

于 2009-08-14T17:50:27.087 回答
0

问题基本上是您的模型没有标准化:您告诉 hibernate 有一个复合键,但您只使用该键的一部分来引用表。

我认为您可以通过在您的产品中设置一组人员并且每个人都有一个角色来实现这一点,或者通过将每个组映射到带有您的人员表的单独(链接)表来实现这一点。

另一种更深奥的方法是映射到 a MultiMap:实际上你Map<Role, Set<Person>>的产品中有 a 。Hibernate 不支持这个开箱即用,但我曾经为此编写了一个 UserType

干杯,

-马丁

于 2009-08-14T20:02:18.320 回答