我知道这应该是一个需要解决的非常基本的问题,但是 1)我对 Hibernate 比较陌生,2)我发现的修复程序(似乎)不适用于此处。

这是我得到的例外:

org.hibernate.MappingException: An association from the table POSTS refers to
 an unmapped class: com.beans.User at 
 org.hibernate.cfg.Configuration.secondPassCompileForeignKeys(Configuration.java:1285)

当 Hibernate 尝试配置自身时会发生这种情况。

我正在使用的对象是用户、帖子(抽象超类)、状态和评论(帖子的具体子类)。每个都是来自两个表之一的 bean:用户和帖子。User 对象非常普通:很多描述用户的乏味字段。除了类似的无聊字段之外,状态和评论都有所有者(发布它的用户)。状态与评论的区别在于,状态可以附加评论列表,但没有父级,而评论没有子帖子,但有父级(是的,这基本上是 Facebook)。

根据我的阅读,问题似乎出在多对一映射中,但我似乎找不到任何问题。这是我正在使用的三个配置文件。

hibernate.cfg.xml:

<hibernate-configuration>
    <session-factory>
        ...
        <!-- mapped persistence classes -->
        <mapping resource="User.hbm.xml" />
        <mapping resource="Post.hbm.xml" />
    </session-factory>
</hibernate-configuration>

用户.hbm.xml:

<hibernate-mapping>
    <class name="com.beans.User" entity-name="User" table="USERS" proxy="User">
        <id name="uid" type="java.lang.Integer">
            <column name="uid" />
            <generator class="assigned" />
        </id>
        ...
    </class>
</hibernate-mapping>

Post.hbm.xml:

<hibernate-mapping>
    <class name="com.beans.Post" entity-name="Post" table="POSTS" proxy="Post" abstract="true">
        <id name="pid" type="java.lang.Integer">
            <column name="pid" />
            <generator class="assigned" />
        </id>            
        <discriminator column="type" />
        <one-to-one name="parent" class="com.beans.Post"></one-to-one>
        <many-to-one name="owner" class="com.beans.User" update="false" fetch="select">
            <column name="owner" />
        </many-to-one>
        <property name="postDate" type="java.sql.Timestamp" update="false">
            <column name="post_date" />
        </property>
        <property name="content" type="java.lang.String" update="false">
        <column name="content" />
        </property>
        <property name="type" type="string" update="false">
         <column name="type" />
        </property>

        <subclass name="com.beans.Status" discriminator-value="status">
         <list name="children" inverse="false" table="POSTS" lazy="true">
                <key column="pid" />
             <index />
             <one-to-many class="com.beans.Comment" />
     </list>
        </subclass>

        <subclass name="com.beans.Comment" discriminator-value="comment"></subclass> 
    </class>
</hibernate-mapping>

我感觉我需要在某处指定 Status 包含 Comment 的 ArrayList 这一事实,但这不是通过 Post.hbm.xml 文件中的“list”构造隐式完成的吗?

xml 文件存在于我的类路径 (WEB-INF/classes) 中,并且 .java 文件本身对应用程序也是可见的。见解将不胜感激!

有帮助吗?

解决方案

您发布的异常是由您明确指定实体名称引起的 <class> 声明而不指定它 <many-to-one>. 。实体名称是 特殊属性 用于区分基于同一类的不同映射。您不需要它来进行映射。

也就是说,您的映射还存在多个其他问题:

  1. <one-to-one> 父级的映射是错误的。根据定义,它不可能是一对一的 - 而 一个帖子只有一个父级,另一个帖子可能有同一个父级(尤其是评论),这使得父级的关联结束是一对多的。您需要将其映射为 <many-to-one> 反而。
  2. 评论列表并不是真正的列表,除非您有一个特殊的列来维护其索引(您不会通过空和无效来判断索引) <index/> 宣言)。将其映射为 <bag> 反而。
  3. 评论列表确实应该使用 inverse=true 进行映射。
  4. 本身不是问题,但它使您的映射更难以阅读 - 不需要嵌套 <column> 元素;您可以将其作为属性,或者如果列名称与属性名称匹配,则完全跳过它。同样,在任何地方都使用 update=false 是没有意义的 - 如果您不想更新您的帖子,请不要保存它们:-)

其他提示

对于我这个问题是由试图引用的一个属性,而不是它映射造成的。

在流利的语法我在做这个(错误!)。

mapping.References(x => x.AdvertExpiryDays).Not.Nullable();

而不是这样的(正确!)。

mapping.Map(x => x.AdvertExpiryDays).Not.Nullable();

其中AdvertExpiryDays是一个int NOT的实体。

许可以下: CC-BY-SA归因
不隶属于 StackOverflow
scroll top