0

我们在嵌入式模式下使用 OrientDB,并希望通过 Java api 调用(不使用 SQL ish 语言)直接访问它。我们有一个索引,需要对其执行范围搜索。这是我迄今为止找到的唯一方法:

String startAt = createInternalOIndexSearchableKey(actualKey);
Index<Edge> index = graph.getIndex(indexName, Edge.class);
OrientIndex orientIndex = (OrientIndex) index;
OIndex oIndex = orientIndex.getUnderlying();
boolean INCLUSIVE = true;
boolean ASCENDING = true;
OIndexCursor cursor = oIndex.iterateEntriesMajor(startAt, INCLUSIVE, ASCENDING);
while(cursor.hasNext())
{
    Entry<Object, OIdentifiable> entry = cursor.nextEntry();
    ...process the entry here

偏离正常的公共 API 这么远感觉不舒服。特别是createInternalOIndexSearchableKey的实现:

private String createInternalOIndexSearchableKey(String actualKey) 
{
    // NOTE: Keys passed to OIndex.iterateEntriesMajor must 
    // be in the (undocumented) format: EdgeLabel!=!ActualKey
    return KEY_CAN_DOWNLOAD_PUBCODETIMESTAMP + "!=!" + actualKey;
}

有一个更好的方法吗?

4

1 回答 1

0

OIndexOIndexCursor是 Document 数据库的公共 api,所以不用担心,你可以使用它。但是API的主要目的是为SQL引擎和其他内部组件提供灵活性,所以不是很方便。

我建议您使用 sql 查询,它们提供相同级别的灵活性和更紧凑,使它们的使用更方便。

于 2014-07-21T08:35:09.300 回答