Как получить свойства ребер и вершин в базе данных графов Гремлина и valueMap() в Java

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 возвращают результаты правильно.

но я не могу использовать valueMap () или values ​​() в query2 непосредственно в Java,

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 ​​()) непосредственно в вышеприведенном запросе, я получаю следующую ошибку компиляции: undefined функция valueMap ()
2) Вместо by(valueMap()), by() возвращает только идентификатор вершины и идентификатор ребра. a=v[16576],b=e[2pjpce-6eo-90r9-9ig][edgeA], c=v[8304]}
Не могли бы вы помочь мне решить эту проблему. Я не могу определить, как использовать (valueMap ()) в Java.

1 ответ

Решение

Вы могли бы использовать 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]]]
Другие вопросы по тегам