首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >GraphDb索引策略

GraphDb索引策略
EN

Stack Overflow用户
提问于 2020-01-16 14:07:43
回答 1查看 24关注 0票数 0

请考虑以下json响应。

如果运行图形查询g.V().hasLabel('customer'),响应是:

代码语言:javascript
复制
[
  {
    "id": "75b9bddc-4008-43d7-a24c-8b138735a36a",
    "label": "customer",
    "type": "vertex",
    "properties": {
      "partitionKey": [
        {
          "id": "75b9bddc-4008-43d7-a24c-8b138735a36a|partitionKey",
          "value": 1
        }
      ]
    }
  }
]

如果运行sql查询select * from c where c.label = 'customer',响应是:

代码语言:javascript
复制
[
    {
        "label": "customer",
        "partitionKey": 1,
        "id": "75b9bddc-4008-43d7-a24c-8b138735a36a",
        "_rid": "0osWAOso6VYBAAAAAAAAAA==",
        "_self": "dbs/0osWAA==/colls/0osWAOso6VY=/docs/0osWAOso6VYBAAAAAAAAAA==/",
        "_etag": "\"2400985f-0000-0c00-0000-5e2066190000\"",
        "_attachments": "attachments/",
        "_ts": 1579181593
    }
]

Q:partitionKey部分的结构上存在差异,在索引策略中应该将其引用为/properties/partitionKey/*还是/partitionKey/?

目前我用.

代码语言:javascript
复制
{
    "indexingMode": "consistent",
    "automatic": true,
    "includedPaths": [{
            "path": "/properties/partitionKey/*"
        },{
            "path": "/partitionKey/?"
        },{
            "path": "/label/?"
        }
    ],
    "excludedPaths": [{
            "path": "/*"
        },{
            "path": "/\"_etag\"/?"
        }
    ]
}

蒂娅!

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2020-01-16 18:51:28

这应该作为"/partitionKey“存储在索引策略中,而不是"/properties/partitionKey”

顺便说一句,这里要指出的另一件事是,通常情况下,最好只排除您永远不会查询的路径,而不是包含您将查询的路径。这样,如果将属性添加到图形中,就不必重新构建索引来查询新属性。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/59771407

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档