我正在使用Titan v0.3.1,并希望查看我已经通过createKeyIndex
索引过的键的列表。我怎样才能做到这一点?
最佳答案
正如您自己发现的那样,您可以为此使用Blueprints getIndexedKeys(Vertex.class)
方法,但是Titan类型系统提供的功能比createKeyIndex
多得多。与Titan合作的时间越长,您就越想了解Type Maker系统:
https://github.com/thinkaurelius/titan/wiki/Type-Definition-Overview
在这种情况下,getIndexedKeys
返回的类型可能不够。这是一些Gremlin,可为您提供更多详细信息:
gremlin> g = GraphOfTheGodsFactory.create('/tmp/titan')
13/08/28 16:28:23 INFO diskstorage.Backend: Configuring index [search] based on:
...
13/08/28 16:28:25 INFO cluster.metadata: [Astaroth / Asteroth] [titan] update_mapping [vertex] (dynamic)
==>titangraph[local:/tmp/titan]
gremlin> import static com.thinkaurelius.titan.graphdb.types.system.SystemKey.*
==>import com.tinkerpop.gremlin.*
==>import com.tinkerpop.gremlin.java.*
==>import com.tinkerpop.gremlin.pipes.*
==>import com.tinkerpop.gremlin.pipes.filter.*
==>import com.tinkerpop.gremlin.pipes.sideeffect.*
==>import com.tinkerpop.gremlin.pipes.transform.*
...
==>import static com.thinkaurelius.titan.graphdb.types.system.SystemKey.*
gremlin> import com.thinkaurelius.titan.graphdb.types.*
==>import com.tinkerpop.gremlin.*
==>import com.tinkerpop.gremlin.java.*
==>import com.tinkerpop.gremlin.pipes.*
==>import com.tinkerpop.gremlin.pipes.filter.*
==>import com.tinkerpop.gremlin.pipes.sideeffect.*
==>import com.tinkerpop.gremlin.pipes.transform.*
...
==>import com.thinkaurelius.titan.graphdb.types.*
gremlin> g.newTransaction().getVertices(TypeClass, TitanTypeClass.KEY).collect{[it.name,it.dataType]}
==>[reason, class java.lang.String]
==>[name, class java.lang.String]
==>[type, class java.lang.String]
==>[time, class java.lang.Integer]
==>[place, class com.thinkaurelius.titan.core.attribute.Geoshape]
==>[age, class java.lang.Integer]
您可能需要查看Titan API,以获取有关从对
TitanKey
的调用返回的getVertices
的更多信息(因为类型存储为顶点):http://thinkaurelius.github.io/titan/javadoc/0.3.2/com/thinkaurelius/titan/core/TitanKey.html
关于gremlin - 如何获取Titan中的索引键列表?,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/18496466/