前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >并行一度关系查询

并行一度关系查询

作者头像
马超的博客
发布2022-09-02 10:26:55
6400
发布2022-09-02 10:26:55
举报
文章被收录于专栏:马超的博客

@TOC[1] Here's the table of contents:

•一、查询需求•二、编写一个基础查询•三、使用并行优化查询

并行一度关系查询

大数据量下并行查询可以显著提升查询性能,通过巧妙的使用Cypher并搭配存储过程,可以实现很多实用的查询。

一、查询需求

[A=[A1,A2,A3,…,An],B=[B1,B2,B3,…,Bm],A和B是两个节点集合。需要查询A中的每个元素分别和B中每个元素是否有一度关系,并返回有关系的实体对。并行一度关系查询问题[2]

二、编写一个基础查询

这个查询实现了寻找A中的每个元素分别和B中每个元素是否有一度关系的需求,实现了基本的功能。查询执行时是顺序执行,无法并行。 在查询的上半段定义了集合a和b,使用笛卡儿积的方式组合两个列表的元素传入下半段查询,即apoc.cypher.run的部分。在apoc.cypher.run中实现了判断两节点是否有一度关系的查询,当没有关系时查询不会下推执行。在RETURN部分返回关系的开始与结束节点。

代码语言:javascript
复制
WITH 
  ['Lilly Wachowski','Carrie-Anne Moss','Laurence Fishburne'] AS a,
  ['Taylor Hackford','Al Pacino','Charlize Theron'] AS b
UNWIND a AS ale
UNWIND b AS ble
WITH ale,ble
CALL apoc.cypher.run(
  'MATCH (a:Person)-[r]-(b:Person) WHERE a.name={ale} AND b.name={ble} RETURN r LIMIT 1',
  {ale:ale,ble:ble}
  ) 
  YIELD value 
WITH value.r AS r
RETURN STARTNODE(r) AS sNode,ENDNODE(r) AS eNode

三、使用并行优化查询

查询的基础上,使用apoc.cypher.parallel2并行方式优化,同理多度关系的并行也可以使用这种方式实现。默认情况下,最大并行数为CPU内核数 x 100。例如,如果数据库被分配了4个内核,那么并行的最多进程数为400。通过该语句批量查询时性能至少会有50%以上的提升。

代码语言:javascript
复制
CALL apoc.cypher.parallel2(
'WITH $a AS a,$b AS b 
 UNWIND a AS ale 
 UNWIND b AS ble WITH ale,ble 
 CALL apoc.cypher.run(
         \'MATCH (a:Person)-[r]-()-[*..3]-(b:Person) WHERE a.name={ale} AND b.name={ble} RETURN r LIMIT 1\',
         {ale:ale,ble:ble}
     ) 
     YIELD value 
     WITH value.r AS r 
     RETURN STARTNODE(r) AS sNode,ENDNODE(r) AS eNode
     ',
{a:['Lilly Wachowski','Carrie-Anne Moss','Laurence Fishburne'],b:['Taylor Hackford','Al Pacino','Charlize Theron']},
'a'
)

References

[1] TOC: 并行一度关系查询 [2] 并行一度关系查询问题: http://neo4j.com.cn/topic/61663f0703dea95514def0aa

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2021-10-13,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 马超的博客 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 并行一度关系查询
  • 一、查询需求
  • 二、编写一个基础查询
  • 三、使用并行优化查询
    • References
    领券
    问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档