gpt4 book ai didi

cassandra - 如何在gremlin titan图数据库和java中的valueMap()中获取边和顶点属性

转载 作者:行者123 更新时间:2023-12-02 22:59:22 25 4
gpt4 key购买 nike

ts1=graph.addVertex(label,"test","test_id",872)
ts2=graph.addVertex(label,"test","test_id",873)
rj1=graph.addVertex(label,"req","id1",113,"status","S")
rj2=graph.addVertex(label,"req","id1",114,"status","S")
e1=rj1.addEdge("edgeA",ts1,"seq",1)
e2=rj2.addEdge("edgeA",ts2,"seq",2)

我能够在单独的查询中获得以下内容:

g.V().hasLabel("req").has("status","S").outE("edgeA").valueMap()
==>[seq:1]
==>[seq:2]
g.V().hasLabel("job").has("status","S").outE("job_edge").inV().valueMap()
==>[test_id,872]
==>[test_id,873]

如何在单个查询中同时获取序列和相应的 test_id
更新的问题:

public void readTestbedJob(String tbName){
GraphTraversalSource traversalSource = getTitanTraversalSource();
GraphTraversal<Vertex, Map<String, Object>> query1 = traversalSource.V()
.has("req","id1",113).valueMap();
GraphTraversal<Vertex, Map<String, Object>> query2 = traversalSource.V().has("status","S").as("a").
outE("edgeA").as("e").
inV().as("v").
select("a","e","v").by(valueMap());
}

从 gremlin 控制台:query1 和 query2 都正确返回结果。

但是,我无法直接在java中使用query2中的valueMap()或values(),

GraphTraversal<Vertex, Map<String, Object>> query2 = traversalSource.V().has("status","S").as("a").
outE("edgeA").as("e").
inV().as("v").
select("a","e","v").by(valueMap());

1)当我直接在上面的查询中使用 by(valueMap()) 或 by(values()) 时,出现以下编译错误:未定义的函数 valueMap()
2)by() 只返回顶点 id 和边 id,而不是 by(valueMap())。a=v[16576],b=e[2pjpce-6eo-90r9-9ig][edgeA],c=v[8304]}
你能帮我解决这个问题吗?我无法确定如何在 Java 中使用 by(valueMap())。

最佳答案

您可以使用select():

gremlin> g.V().has("job_status","S").
......1> outE("edgeA").as('e').
......2> inV().as('v').
......3> select('e','v').by(valueMap())
==>[e:[sequence:1],v:[test_suite_id:[872]]]
==>[e:[sequence:2],v:[test_suite_id:[873]]]

关于cassandra - 如何在gremlin titan图数据库和java中的valueMap()中获取边和顶点属性,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43672338/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com