Neo4j节点索引:如何更改Lucene的默认相似度?

时间:2012-12-16 01:06:39

标签: java lucene neo4j similarity

我正在使用neo4j(1.9)和lucene core 3.5,通过neo4j-lucene-index库提供的支持。 在我的代码中,我创建了一个新的节点索引:

    HashMap<String, String> stringMap = new HashMap<String, String>();
    stringMap.put("type", "fulltext");
    stringMap.put(IndexManager.PROVIDER, "lucene");
    stringMap.put("to_lower_case", "false");
    stringMap.put("similarity", MySimilarity.class.getName());
    stringMap.put("analyzer", MyAnalyzer.class.getName());
    simpleIndex = (LuceneIndex<Node>) template.getGraphDatabaseService()
            .index().forNodes("simple-index", stringMap);

并通过多字段查询查询节点索引:

    Analyzer analyzer = new MyAnalyzer();
    Query query = null;
    try {
        query = MultiFieldQueryParser.parse(Version.LUCENE_35,
                queriesArray, fieldsArray, flagsArray, analyzer);
    } catch (ParseException e) {
        e.printStackTrace();
        return;
    }
    if (query == null)
        return;
    QueryContext qc = new QueryContext(query).sortByScore();
    IndexHits<Node> hits = simpleIndex.query(qc);

如何将用于按分数排序的Similarity实现更改为MySimilarity类(扩展DefaultSimilarity并覆盖其某些方法)?报告的查询总是使用DefaultSimilarity,我无法找到任何钩子来设置我在查询期间激活的搜索器使用的相似性。

1 个答案:

答案 0 :(得分:2)

在查询期间未使用提供的相似性这一事实是一个错误,应该修复。创建了https://github.com/neo4j/neo4j/issues/375来跟踪它。