Loading [MathJax]/jax/output/CommonHTML/config.js
前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >并行一度关系查询

并行一度关系查询

作者头像
马超的博客
发布于 2022-09-02 02:26:55
发布于 2022-09-02 02:26:55
72600
代码可运行
举报
文章被收录于专栏:马超的博客马超的博客
运行总次数:0
代码可运行

@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
代码运行次数:0
运行
AI代码解释
复制
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
代码运行次数:0
运行
AI代码解释
复制
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 删除。

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

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
Java8 Date API
Java8 在 java.time 包下新增了全新的日期和时间 API。新的 Date API 与 Joda-Time 库有点相似,但又有不一样。
happyJared
2019/08/02
8480
一文带你入坑JDK8的新日期时间类 LocalDate、LocalTime、LocalDateTime
参考 https://blog.csdn.net/duan196_118/article/details/111597682 https://blog.csdn.net/qq_24754061/article/details/95500209 https://xijia.blog.csdn.net/article/details/106007147
时间静止不是简史
2023/02/23
4.9K0
一文带你入坑JDK8的新日期时间类 LocalDate、LocalTime、LocalDateTime
java获取当前日期和时间(各种方法对比)
System.currentTimeMillis()产生一个当前的毫秒,这个毫秒其实就是自1970年1月1日0时起的毫秒数,类型为long; Date:
ha_lydms
2023/08/09
3.2K0
java获取当前日期和时间(各种方法对比)
java各个时间类总结归纳,最全一篇
本文主要针对Date、Calendar、Instant、LocalDate、LocalTime和LocalDateTime的使用做了介绍并进行了对比,同时对simpleDateFormat和simpleDateFormat进行了对比和介绍。篇幅较长可针对具体模块选择性阅读。
公众号 IT老哥
2020/09/16
6810
java各个时间类总结归纳,最全一篇
java最全最常用的日期工具类(随时补充)
@Slf4j public final class DateUtils { private DateUtils() { } private static final String FORMAT_YYYYMMDDHHMMSS = "yyyy-MM-dd HH:mm:ss"; public static final String FORMAT_YYYY_MM_DD = "yyyy-MM-dd"; public static final String FORMAT_
疯狂的KK
2023/04/10
1.2K0
JSR310新日期API(三)-日期时间格式化与解析
前一篇文章已经比较详细地介绍了JSR-310中新增的常用的日期时间类,在实际应用中,我们也十分关注这些日期时间类的格式化操作,更加通俗来说就是字符串和日期时间类的相互转换问题。下面先回顾一下Java旧有的日期时间类和字符串之间的转换方案,然后重点分析JSR-310中新增的常用的日期时间类和字符串之间的转换方案。
Throwable
2020/06/23
1.6K0
【Java 基础篇】Java 日期类详解
日期和时间在软件开发中是非常常见且重要的概念。Java 提供了一套强大的日期和时间 API,用于处理日期、时间、时区等相关操作。本文将详细介绍 Java 日期类的概念、用法和常见操作,并提供一些示例代码。
繁依Fanyi
2023/10/12
3520
java 8 日期操作,真香!
java 8 的日期类已经出来很长一段时间了,一直以来也没怎么用过,最近用到了感觉太好用了,真香。
索码理
2022/09/20
6310
Java 8 的时间日期 API
上一篇文章『Java 的时间日期 API』中,我们学习了由 Date、Calendar,DateFormat 等组成的「传统时间日期 API」,但是传统的处理接口设计并不是很友好,不易使用。终于,Java 8 借鉴第三方优秀开源库 Joda-time,重新设计了一套 API。 那么本篇文章就来简单学习一下新式的时间日期处理接口。 表示时刻的 Instant Instant 和 Date 一样,表示一个时间戳,用于描述一个时刻,只不过它较 Date 而言,可以描述更加精确的时刻。并且 Instant 是时区无
Single
2018/05/09
1.6K0
Java 编程问题:三、使用日期和时间
本章包括 20 个涉及日期和时间的问题。这些问题通过Date、Calendar、LocalDate、LocalTime、LocalDateTime、ZoneDateTime、OffsetDateTime、OffsetTime、Instant等涵盖了广泛的主题(转换、格式化、加减、定义时段/持续时间、计算等)。到本章结束时,您将在确定日期和时间方面没有问题,同时符合您的应用的需要。本章介绍的基本问题将非常有助于了解日期-时间 API 的整体情况,并将像拼图中需要拼凑起来的部分一样解决涉及日期和时间的复杂挑战。
ApacheCN_飞龙
2022/07/11
5.6K0
Java时间日期库java.time:什么是java.time包?如何替代旧的Date与Calendar?
在本文中,猫头虎将带你全面了解java.time包的核心特性、使用方法,以及如何用它替代旧的Date与Calendar类,帮助你轻松处理时间与日期问题。 🚀
猫头虎
2024/12/24
2350
Java获取当前时间/日期/时间戳及格式化总结,附代码
概念:格林威治时间1970年01月01日00时00分00秒到现在的总秒数,共10位,单位为秒
全栈程序员站长
2022/10/04
7.5K0
Java获取当前时间/日期/时间戳及格式化总结,附代码
【Java8新特性】06 新的日期和时间:LocalDate LocalTime LocalDateTime
java.util.Date类是Jdk 1.0引入的,易用性非常糟糕,比如年份的起始是1900年,月份的起始是0。比如要表示2019年6月18日,创建一个Date实例:
爱笑的架构师
2020/09/24
1.3K0
【Java8新特性】06 新的日期和时间:LocalDate LocalTime LocalDateTime
jdk8获取当前时间|时间加减|java8时间格式化|时间处理工具|时间比较|线程安全的时间处理方法
在很久之前,我总结了一些jdk7版本之前的关于时间处理的一些公共方法,日期转换成字符串、指定时间加上指定天数后的日期、获取上周周一时间 等等;具体的可以戳链接查看完整的:https://blog.csdn.net/qq_27471405/article/details/79523556
小小鱼儿小小林
2020/06/24
7.5K0
jdk8获取当前时间|时间加减|java8时间格式化|时间处理工具|时间比较|线程安全的时间处理方法
Java 日期和时间 API:实用技巧与示例 - 轻松处理日期和时间
如果您尝试读取与预期类型不同的数据,则会抛出 InputMismatchException 异常。您可以使用 try-catch 块来处理此异常。
小万哥
2024/03/07
1900
Java 日期和时间 API:实用技巧与示例 - 轻松处理日期和时间
日期工具类-操作字符串和Date、LocalDate互转,两个日期的时间差等
避免重复造轮子,相关方法基于hutool日期时间工具封装并做部分增强。需要先引入如下坐标
共饮一杯无
2022/11/28
1.3K0
时间处理的未来:Java 8全新日期与时间API完全解析
3.LocalDateTime: 用于表示不含时区的日期时间,例如:2024-07-06T10:30:15。
忆愿
2025/01/15
1210
时间处理的未来:Java 8全新日期与时间API完全解析
Java中关于时间日期的API
小尘要自信
2023/10/10
2980
Java 基础概念·Java 日期与时间
在计算机中,通常使用 Locale 表示一个国家或地区的日期、时间、数字、货币等格式。Locale 由 语言_国家 的字母缩写构成,例如,zh_CN 表示中文+中国,en_US 表示英文+美国。语言使用小写,国家使用大写。
数媒派
2022/12/01
5.3K0
玩转 Java 时间 + 面试题
在 JDK 8 之前,Java 语言为我们提供了两个类用于操作时间,它们分别是:java.util.Date 和 java.util.Calendar,但在 JDK 8 的时候为了解决旧时间操作类的一些缺陷,提供了几个新的类,用于操作时间和日期,它们分别是:LocalTime、LocalDateTime、Instant,都位于 java.time 包下。时间的操作在我们日常的开发中经常见到,比如,业务数据都要记录创建时间和修改时间,并要把这些时间格式化之后显示到前端页面,再比如我们需要计算业务数据的时间间隔等,都离不开对时间的操作,那如何正确而优雅地使用时间?这就是我们接下来要讨论的话题。
架构师修炼
2020/07/17
1.1K0
推荐阅读
相关推荐
Java8 Date API
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
本文部分代码块支持一键运行,欢迎体验
本文部分代码块支持一键运行,欢迎体验