在给定edgeId的情况下,我希望获得具有边属性的进出顶点。
我尝试了以下几种方法:
final String edgeId = "edge-nk1-to-nk2";
g.addV("nk_node").property(T.id, "nk1").property("name", "name-nk1").as("n1")
.addV("nk_node").property(T.id, "nk2").property("name", "name-nk2").as("n2")
.addE("friend").property(T.id, edgeId).property("name", "edge-name-prop-value").from("n1").to("n2")
.next();
System.out.println("---------------------------------------------------------------------------------");
final Object usingBothVOutput = g.E(edgeId).as("edge")
.bothV().as("nodes")
.select("edge", "nodes").by(valueMap(true))
.toList();
System.out.println(usingBothVOutput);
System.out.println("--------------------------------------------------------------------------------");
final Path path = g.E(edgeId).as("edge").bothV().path().next();
System.out.println(path);带输出:
---------------------------------------------------------------------------------
[{edge={id=edge-nk1-to-nk2, label=friend, name=edge-name-prop-value}, nodes={id=nk1, label=nk_node, name=[name-nk1]}}, {edge={id=edge-nk1-to-nk2, label=friend, name=edge-name-prop-value}, nodes={id=nk2, label=nk_node, name=[name-nk2]}}]
--------------------------------------------------------------------------------
path[e[edge-nk1-to-nk2][nk1-friend->nk2], v[nk1]]第一个查询输出有两个节点,但没有指示哪个节点是IN,哪个节点是OUT。路径查询显式地指定了IN和OUT顶点,但是它没有边的属性。
发布于 2019-06-26 15:51:03
如果要使用path步骤,可以添加by
g.E(edgeId).as("edge").bothV().path().by(valueMap(true))此外,您还可以尝试使用project
g.E(edgeId).project("out", "in").by(outV().valueMap(true)).by(inV().valueMap(true))https://stackoverflow.com/questions/56761351
复制相似问题