如何使用tinkerpop API 3在复合索引的titan 1.0中进行不区分大小写的搜索

时间:2016-03-08 04:52:17

标签: indexing composite titan

我在titan 1.0中的属性上创建了一个复合索引。现在我想对该属性进行不区分大小写的搜索。

如下创建复合索引:

TitanManagement mgmt = graph.openManagement();

TitanManagement.IndexBuilder nameIndexBuilder = mgmt.buildIndex("name_comp_idx", Vertex.class).addKey("name");

titanGraphIndex = nameIndexBuilder.buildCompositeIndex();

顶点:

TitanVertex vertex= graph.addVertex(T.label, "company");
        entity.property("name", "APPLE");

以下查询用于使用Tinkerpop API 3搜索titan图。

graph.traversal().V().has("name", "apple").toList()

但没有结果返回..

有人可以告诉我们如何对titan复合索引进行不区分大小写的搜索吗?有没有其他方法可以实现相同的目标?

1 个答案:

答案 0 :(得分:2)

如Titan文档中所述,composite indexes用于完全匹配

一种选择是将属性存储两次,一次使用实际值,一次使用较小值。您可以通过以下几种方式实现这一目标:

mgmt = graph.openManagement()
// store the property twice, once with the real value, once with a lowercased value
// for name, we're using different property names
name = mgmt.makePropertyKey('name').dataType(String.class).cardinality(Cardinality.SINGLE).make()
nameLower = mgmt.makePropertyKey('nameLower').dataType(String.class).cardinality(Cardinality.SINGLE).make()
nameLowerIndex = mgmt.buildIndex('nameLowerIndex', Vertex.class).addKey(nameLower).buildCompositeIndex()
// for title, we're using a list
title = mgmt.makePropertyKey('title').dataType(String.class).cardinality(Cardinality.LIST).make()
titleListIndex = mgmt.buildIndex('titleListIndex', Vertex.class).addKey(title).buildCompositeIndex()
mgmt.commit()

v = graph.addVertex()
h = 'HERCULES'
v.property('name', h)
v.property('nameLower', h.toLowerCase())
t = 'GOD'
v.property('title', t)
v.property('title', t.toLowerCase())
graph.tx().commit()

g.V(v).valueMap()
g.V().has('nameLower', 'hercules').values('name')
// within predicate is defined in org.apache.tinkerpop.gremlin.process.traversal.P
g.V().has('title', within('god')).values('title').next()

另一种选择是使用带有Mapping.TEXT的混合索引和文本谓词,但要注意full-text search涉及的陷阱。

// Full-text search
mgmt = graph.openManagement()
name = mgmt.makePropertyKey('name').dataType(String.class).cardinality(Cardinality.SINGLE).make()
nameIndex = mgmt.buildIndex('nameIndex', Vertex.class).addKey(name).buildMixedIndex('search')
mgmt.commit()

v = graph.addVertex()
v.property('name', 'HERCULES')
graph.tx().commit()

// wait for a moment
Thread.sleep(n)
// text predicates are defined in com.thinkaurelius.titan.core.attribute.Text
// import static com.thinkaurelius.titan.core.attribute.Text.*
g.V().has('name', textContains('hercules')).values('name')