休眠:未映射的类关联异常
-
21-09-2019 - |
题
我知道这应该是一个需要解决的非常基本的问题,但是 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>
. 。实体名称是 特殊属性 用于区分基于同一类的不同映射。您不需要它来进行映射。
也就是说,您的映射还存在多个其他问题:
<one-to-one>
父级的映射是错误的。根据定义,它不可能是一对一的 - 而 这 一个帖子只有一个父级,另一个帖子可能有同一个父级(尤其是评论),这使得父级的关联结束是一对多的。您需要将其映射为<many-to-one>
反而。- 评论列表并不是真正的列表,除非您有一个特殊的列来维护其索引(您不会通过空和无效来判断索引)
<index/>
宣言)。将其映射为<bag>
反而。 - 评论列表确实应该使用 inverse=true 进行映射。
- 本身不是问题,但它使您的映射更难以阅读 - 不需要嵌套
<column>
元素;您可以将其作为属性,或者如果列名称与属性名称匹配,则完全跳过它。同样,在任何地方都使用 update=false 是没有意义的 - 如果您不想更新您的帖子,请不要保存它们:-)
其他提示
对于我这个问题是由试图引用的一个属性,而不是它映射造成的。
在流利的语法我在做这个(错误!)。
mapping.References(x => x.AdvertExpiryDays).Not.Nullable();
而不是这样的(正确!)。
mapping.Map(x => x.AdvertExpiryDays).Not.Nullable();
其中AdvertExpiryDays是一个int NOT的实体。