我有以下结构:Neo4j Cypher基于相关节点属性的查询。获取节点,最大属性值
(A)-[:many]->(B)-[:also_many]->(C)
B
有一个名称属性。并且C
有日期属性。 A
有很多B
相关,并且每个B
有很多C
有关。
我想获得唯一B
连同C
其中c.date
是最高的。
日期存储如下:“YYYY-MM-DD HH:MM:SS”。我正在使用apoc.date.parse(date)
来获取时间戳值。
难道真的不想弄清楚如何继续这个。
样本数据集:
create (o:A {outlet: "SFO"}), (a:B {name: "Varun", date: "2017-04-01 00:00:00"}), (b:B {name: "Karen", date: "2017-04-12 00:00:00"}), (c:B {name: "Vicky", date: "2017-06-01 00:00:00"}), (aa:C {date: "2017-09-8 00:00:00", tag_no: "R2017123"}), (ab:C {date: "2017-09-02 00:00:00", tag_no: "R2017321"}), (ac:C {date: "2017-09-10 00:00:00", tag_no: "R2017423"}), (ad:C {date: "2017-09-23 00:00:00", tag_no: "R2017523"}), (ae:C {date: "2017-09-10 00:00:00", tag_no: "R2017930"}), (ba:C {date: "2017-09-02 00:00:00", tag_no:"R2017928"}), (bb:C {date: "2017-09-15 00:00:00", tag_no:"R2017039"}), (bc:C {date: "2017-09-10 00:00:00", tag_no:"R2017837"}), (bd:C {date: "2017-09-08 00:00:00", tag_no:"R2017022"}), (be:C {date: "2017-09-10 00:00:00", tag_no:"R2017883"}), (ca:C {date: "2017-09-11", tag_no:"R2017827"}), (cb:C {date: "2017-09-18", tag_no:"R2017322"}), (cc:C {date: "2017-09-21", tag_no:"R2017122"}), (cd:C {date: "2017-09-16", tag_no:"R2017877"}), (ce:C {date: "2017-09-08", tag_no:"R2017930"}), (o)-[:owns]->(a),(o)-[:owns]->(b),(o)-[:owns]->(c),(a)-[:subs]->(aa),(a)-[:subs]->(ab),(a)-[:subs]->(ac),(a)-[:subs]->(ad),(a)-[:subs]->(ae),(b)-[:subs]->(ba),(b)-[:subs]->(bb),(b)-[:subs]->(bc),(b)-[:subs]->(bd),(b)-[:subs]->(be),(c)-[:subs]->(ca),(c)-[:subs]->(cb),(c)-[:subs]->(cc),(c)-[:subs]->(cd),(c)-[:subs]->(ce);
我需要两个查询:
我想返回有日起说2014-04-01
和和最新的相关C
节点每个B
节点B
节点B.date
。在数据集中,我有两个C
节点,它们具有相同的date
。但查询应该只返回每个B
节点的一个结果。
而第二查询是:
返回与上述的值,内日期B
节点不具有与日期范围内日期C
节点,说“2017年9月1日”和“2017-09 -09" 。
为什么你需要APOC这个?这种格式的日期可以按照字典顺序排列,所以'ORDER BY c.date DESC LIMIT 1'应该可以让你获得最大的价值。当然,如果你想使用这个日期,你必须解析它,但你可以在应用程序代码中做到这一点。 –
我正在尝试使用max()函数,并且此日期格式不兼容。 – notANerdDev
什么是'字典学'?这对我来说是一个新名词。是否有一个函数可以获得几个节点的最高日期? – notANerdDev