如何在RedisGraph中返回关系?

时间:2019-01-16 23:34:55

标签: redisgraph

使用RedisGraph,我希望QUERY返回一个关系的类型。

查询示例:

MATCH (n1:Entity { id: "foo" }) MATCH (n2:Entity2 { id: "bar" }) CREATE (n1)-[r:areFriends]->(n2) RETURN *

不幸的是,返回的值仅包含n1n2,但不包含r

返回的记录包含以下内容:

Record { _header: [ 'n1.id', 'n1.name', 'n2.id', 'n2.name' ] 这符合我的架构,但众所周知r在那里缺失。

如何获得RETURN以返回关系?

OpenCypher支持如下语法:

RETURN n1, n2, type(r),但这在RedisGraph中似乎不起作用。

2 个答案:

答案 0 :(得分:1)

PR刚合并到MASTER

127.0.0.1:6379> GRAPH.QUERY G "create (:Entity {id:'foo'}), (:Entity {id:'bar'})"
1) (empty list or set)
2) 1) "Labels added: 1"
   2) "Nodes created: 2"
   3) "Properties set: 2"
   4) "Query internal execution time: 0.536000 milliseconds"

127.0.0.1:6379> GRAPH.QUERY G "MATCH (n1:Entity {id:'foo'}), (n2:Entity {id:'bar'}) CREATE (n1)-[r:areFriends]->(n2) RETURN n1,n2,TYPE(r)"
1) 1) 1) "n1.id"
      2) "n2.id"
      3) "TYPE(r)"
   2) 1) "foo"
      2) "bar"
      3) "areFriends"
2) 1) "Relationships created: 1"
   2) "Query internal execution time: 0.409000 milliseconds"

请注意,此更改将是1.0.12版的一部分

在该版本发布之前,您可以从源代码构建,也可以使用docker image redislabs / redisgraph:edge

答案 1 :(得分:0)

尽管RedisGraph尚在进行中,但目前尚不支持混合CREATE和RETURN子句,并且应该在几天之内就可以使用。