首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >优化Neo4j查询

优化Neo4j查询
EN

Stack Overflow用户
提问于 2020-06-15 13:55:37
回答 1查看 40关注 0票数 0
代码语言:javascript
复制
match (m:Server)-[r]-(n:Middleware)-[r1]-(o:OperatingSystem),
(y:DeploymentUnit{name:n.name+m.name}) merge(y)-[:STRATEGIC_RUNS_ON]->(o) merge(y)<-[:STRATEGIC_OUT_RUNS_ON]-(o)

我在运行这个查询,但是complete.Is花了一个多小时,我可以优化这个查询。服务器节点:10035,中间件节点:2334,OperatingSystem节点:43,DeploymentUnit节点:5014。

提前感谢

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2020-06-15 15:14:09

您可以通过以下方式改进此查询:

在DeploymentUnit标签的名称属性上创建索引,用于匹配

代码语言:javascript
复制
CREATE INDEX FOR (n:DeploymentUnit) ON (n.name)

使用避免查询中的笛卡儿积

代码语言:javascript
复制
MATCH (m:Server)-[r]-(n:Middleware)-[r1]-(o:OperatingSystem)
WITH n.name+m.name as du_name, o
MATCH (y:DeploymentUnit{name: du_name}) 
MERGE (y)-[:STRATEGIC_RUNS_ON]->(o) 
MERGE (y)<-[:STRATEGIC_OUT_RUNS_ON]-(o)
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/62389717

复制
相关文章

相似问题

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