4

我有实体“用户”和“客户”:

@Entity
@Table(name = "USR_USER")
public class User extends PersistentObject {

   [...]

   @Any(metaColumn = @Column(name = "USR_OWNERTYPE"))
   @AnyMetaDef(idType = "long", metaType = "string", metaValues = {
         @MetaValue(targetEntity = Customer.class, value = "CST"),
         @MetaValue(targetEntity = Client.class, value = "CLT") })
   @JoinColumn(name = "USR_OWNERID")
   private PersistentObject owner;
}

@Entity
@Table(name = "CST_CUSTOMER")
public class Customer extends PersistentObject {

   @Id
   @GeneratedValue
   @Column(name="CST_ID")
   private long id;

   [...]

   // @OneToMany(mappedBy = "owner")
   private transient Set<User> users;
}

运行这个(使用spring),我得到了以下异常:

Caused by: org.hibernate.MappingException: Foreign key (FK35B91BB65D577CEF:USR_USER [USR_OWNERTYPE,USR_OWNERID])) must have same number of columns as the referenced primary key (CST_CUSTOMER [CST_ID])

我不明白这一点,因为我将@AnyMetaDef(在“User”中)中的“Customer”类映射到常量“CST”。

我究竟做错了什么?

提前感谢托马斯的任何帮助

4

1 回答 1

1

“不可能为这种关联指定外键约束。” -- http://docs.jboss.org/hibernate/core/3.6/reference/en-US/html/mapping.html#mapping-types-anymapping

编辑:你想要的@Any 的另一端是@OneToAny,它不存在。可能是您在不合适的地方使用了 @Any 映射。再次来自文档:“这不是映射多态关联的常用方法,您应该仅在特殊情况下使用它。例如,用于审计日志、用户会话数据等。”

仔细看看继承映射,看看其中一个是否不是映射关系的更合适的方式。

于 2011-08-24T21:42:58.343 回答