1

我收到了这个休眠错误:

org.hibernate.MappingException: Could not determine type for: 
a.b.c.Results$BusinessDate, for columns: [org.hibernate.mapping.Column(businessDate)]

课程如下。有谁知道我为什么会收到这个错误?

@XmlAccessorType(XmlAccessType.FIELD)
@XmlType(name = "", propOrder = {
    "businessDate"
})
@XmlRootElement(name = "Results")
@Entity(name = "Results")
@Table(name = "RESULT")
@Inheritance(strategy = InheritanceType.JOINED)
@Cache(usage = CacheConcurrencyStrategy.READ_ONLY)
public class Results implements Equals, HashCode
{

    @XmlElement(name = "BusinessDate", required = true)
    protected Results.BusinessDate businessDate;

    public Results.BusinessDate getBusinessDate() {
        return businessDate;
    }

    public void setBusinessDate(Results.BusinessDate value) {
        this.businessDate = value;
    }

    @XmlAccessorType(XmlAccessType.FIELD)
    @XmlType(name = "", propOrder = {
        "raw",
        "display"
    })
    @Entity(name = "Results$BusinessDate")
    @Table(name = "BUSINESSDATE")
    @Inheritance(strategy = InheritanceType.JOINED)
    public static class BusinessDate implements Equals, HashCode
    {

    ....

更新:此代码由HyperJaxB生成。所以我并没有声称完全了解它,只是试图对其进行一些更改!


Update2:这是完整的(是的,它很大)src 文件

4

2 回答 2

2

使用静态嵌套类作为字段类型很好并且受支持。但是 Hibernate 不知道如何将如此复杂的类型映射到列类型(这是错误消息所说的)。因此,您需要创建一个用户类型来处理此问题,或者使用注释对Results.BusinessDate字段进行@OneToOne注释以将其保留在另一个表中(我还将删除@Inheritancewhich 是无用的,但这不是这里的问题)。

更新:只是为了澄清一下,使用用户类型或将复杂类型映射到@OneToOne 确实有效。以下代码完美运行(经过测试):

@Entity
public class EntityWithStaticNestedClass implements Serializable {
    @Id
    @GeneratedValue
    private Long id;

    @OneToOne
    private EntityWithStaticNestedClass.StaticNestedClass nested;

    public Long getId() { return id; }

    public void setId(Long id) { this.id = id; }

    public EntityWithStaticNestedClass.StaticNestedClass getNested() { 
        return nested;
    }

    public void setNested(EntityWithStaticNestedClass.StaticNestedClass nested) {
        this.nested = nested;
    }

    @Entity
    public static class StaticNestedClass implements Serializable {
        @Id
        @GeneratedValue
        private Long id;

        public Long getId() { return id; }

        public void setId(Long id) { this.id = id; }
    }
}

并且两个实体都很好地保存在各自的表中。但是您没有显示整个代码,也没有显示确切的错误,所以我不能说为什么它不适合您(也许您错过了@Id等)。

话虽如此,如果您根本不想被持久化,请使用(使用 JPA,默认情况下字段是持久化的)businessDate对其进行注释:@Transient

更新:您不能混合使用字段和属性访问。所以你需要在getBusinessDate()这里注释@Transient。抱歉,我无法从显示的代码中猜到这一点,我认为这很明显。

于 2010-04-09T23:14:08.087 回答
0

与凯文克劳威尔相同的评论。您可能还会考虑不将内部类用于实体类型。我实际上从未见过有人用 Hibernate 做到这一点,所以我不确定它是否可能,或者你将如何映射它。

BusinessDate 内部类上的 @Inheritance 注释似乎也有点可疑 - 内部类是静态的,并且不会从另一个实体继承,除非 Hibernate 将内部类视为“继承的”。

总的来说,不太确定你想要完成什么,但你可能会让你的生活变得比应该的更难。我建议不要使用内部类,而只是以更简单/直接的方式映射所有实体。

于 2010-04-09T22:29:26.853 回答