2

我正在使用 OrientDB 2.1.6 对象 API。

我有两个 POJO 具有这样的 1 对 N 关系:

public static class Results {
    private String userId;
    private String templateId;
    private Double totalLength;
    private List<String> visibleFields;
    private Boolean filterable;
    @OneToMany(orphanRemoval = true)
    private List<ResultItem> items;

    //Generic getters and setters
}

public static class ResultItem {
    private String id;
    private String vsId;
    private String entryTemplateId;
    private String objectType;
    private String objectTypeLabel;
    private String capabilityComment;
    private Boolean currentVersion;
    private Double contentSize;
    private String name;
    private String objectStoreId;
    private String mimeType;
    private HashMap<String, String> attributes;
    private Date dateLastModified;

    //generic getters and setters
}

这在 OrientDB 中创建了两个类。如果我使用 Object API 删除 Results 实例,它将正确删除关联的 ResultItem 行。

我正在尝试使用“控制台”删除特定的 ResultItem 记录,如下所示:

orientdb {db=test}> find references #15:6392 Found
[{rid:#15:6392,referredBy:[1]}] in 0.014000 sec(s).

orientdb {db=test}> delete from ResultItem where @rid=#15:6392 Delete
record(s) '1' in 0.006000 sec(s).

orientdb {db=test}> find references #15:6392 Found
[{rid:#15:6392,referredBy:[1]}] in 0.014000 sec(s).

控制台输出表明该记录已被删除,但它仍然包含“引用”。

当我回到 Object api 并尝试 db.detachAll(results, true); 时,这本身就是一个问题。它抛出了这个异常,我认为这是由于孤儿关系。

Caused by: java.lang.NullPointerException
    at com.orientechnologies.orient.object.db.OObjectLazyList.convertAndDetachAll(OObjectLazyList.java:456)
    at com.orientechnologies.orient.object.db.OObjectLazyList.convertAndDetachAll(OObjectLazyList.java:432)
    at com.orientechnologies.orient.object.db.OObjectLazyList.detachAll(OObjectLazyList.java:424)
    at com.orientechnologies.orient.object.enhancement.OObjectProxyMethodHandler.detachAll(OObjectProxyMethodHandler.java:165)
    at com.orientechnologies.orient.object.enhancement.OObjectEntitySerializer.detachAll(OObjectEntitySerializer.java:261)
    at com.orientechnologies.orient.object.db.OObjectDatabaseTx.detachAll(OObjectDatabaseTx.java:809)
    at com.orientechnologies.orient.object.db.OObjectDatabaseTx.detachAll(OObjectDatabaseTx.java:327)

如何删除关系以及记录?

4

1 回答 1

1

我试过你的案子,我得到了同样的结果。

这是对引用的限制,因为没有检查@RID一致性,当您删除文档时,删除所有引用将激活数据库的完整扫描,以搜索与第一个链接的所有文档,然后删除引用。

这将是一项非常昂贵的操作,并且会花费大量时间,这是原因之一,因为建议使用边缘而不是LINKS, LINKLIST,...

希望能帮助到你

于 2016-04-26T13:57:30.493 回答