0

我想添加一个附件实体,我将从多个不同的实体中引用它,但它没有引用这些实体,我如何让它在 ORMLite 中工作?

我不断收到此异常:

 Caused by: java.sql.SQLException: Foreign collection class entity.Attachment for
    field 'attachments' column-name does not contain a foreign field named
    'attachmentId' of class enity.News

例如我有一个新闻实体

@DatabaseTable
public class News extends Record {

    @DatabaseField(index = true, id = true)
    private long newsArticleId;
    @DatabaseField
    private String subject;
    @DatabaseField
    private String content;

    @ForeignCollectionField
    Collection<Attachment> attachments;
}

附件实体:

@DatabaseTable
public class Attachment extends Record {

    @DatabaseField(id = true, index = true)
    private long attachmentId;

    @DatabaseField
    private String attachmentUrl;
}

有人可以指着我笑,告诉我为什么我做错了,我在这里误解了什么。谢谢。

4

1 回答 1

1

这是一个常见问题解答。引用ORMLite docs on foreign-collections

请记住,当您有 ForeignCollection 字段时,集合中的类必须(在本例中Order)必须具有用于具有该集合的类的外部字段(在本例中Account)。如果Account有一个外部集合Orders,则Order必须有一个Account外部字段。它是必需的,以便 ORMLite 可以找到与特定帐户匹配的订单。

在您的示例中,为了让ORMLite找出Attachment特定News实体具有的特定实体,该Attachment实体必须具有一个News字段。另一种方法是创建一个连接表,但 ORMLite 不会为您这样做。

于 2015-01-24T23:10:19.080 回答