我试图用JanusGraph在Gremlin shell中输出一个子图作为GraphSON。
TinkerPop文档供参考: http://tinkerpop.apache.org/docs/current/reference/#graphson-reader-writer
当我编写完整的图形时,这很好,但是,当我想编写一个我使用这些命令查询的子图时:
gremlin> subGraph = g.V(45240).repeat(__.bothE().subgraph('subGraph').bothV()).times(4).cap('subGraph').next()
我使用相同的写命令:
gremlin> subGraph.io(IoCore.graphson()).writeGraph("45240_sub4.json")
我收到此错误:
(是java.lang.IllegalStateException)(通过引用链:org.janusgraph.graphdb.relations.RelationIdentifier [“inVertexId”])
搜索周围,我发现另一个线程说我需要导入一个包以便正确地执行此操作(对于TitanGraph,但我认为它也适用于JanusGraph):Import package in gremlin
但是,每当我尝试导入时:
gremlin> import com.thinkaurelius.titan.graphdb.tinkerpop.io.graphson.TitanGraphSONModule
我收到此错误:
无效的导入定义:'com.thinkaurelius.titan.graphdb.tinkerpop.io.graphson.TitanGraphSONModule';原因:启动失败: script1494618250861805544050.groovy:1:无法解析类com.thinkaurelius.titan.graphdb.tinkerpop.io.graphson.TitanGraphSONModule @第1行,第1列。 import com.thinkaurelius.titan.graphdb.tinkerpop.io.graphson.TitanGraphSONModule ^
1错误
如何使用JanusGraph在Gremlin shell中将子图输出为GraphSON?
答案 0 :(得分:6)
当您使用subgraph()
步骤时,结果为TinkerGraph
,但其顶点和边缘ID是从JanusGraph
实例转移的。特别是,边缘ID的类型为RelationIdentifier
,需要JanusGraph的自定义序列化程序JanusGraphSONModule
才能完全导出。
以下是一个基于Titan的previous example的示例,您可以在Gremlin控制台中运行:
graph = JanusGraphFactory.open('inmemory')
graph.io(graphson()).readGraph('data/tinkerpop-modern.json')
g = graph.traversal()
subGraph = g.E().hasLabel('knows').subgraph('sg').cap('sg').next()
graphsonIO = IoCore.graphson().graph(subGraph).registry(JanusGraphIoRegistry.getInstance()).create()
graphsonIO.writeGraph('/tmp/subgraph.json')
答案 1 :(得分:1)
您可能只需导入该Titan模块的JanusGraph等效项:org.janusgraph.graphdb.tinkerpop.io.graphson.JanusGraphSONModule
所以,这个导入应该有效:
gremlin> import org.janusgraph.graphdb.tinkerpop.io.graphson.JanusGraphSONModule