码迷,mamicode.com
首页 > 其他好文 > 详细

elasticsearch suggest 的几种使用-completion 使用

时间:2014-07-13 13:04:41      阅读:1433      评论:0      收藏:0      [点我收藏+]

标签:Lucene   blog   http   java   使用   os   

在lucene里面,suggest 的支持非常完善,可以随心所欲的定制; 但是在es中使用起来就没有那么方便了。 es给suggest 分类4类:term ;phrase; completion; context; 目前最新版本是es1.2.1 这一块也还在不断完善中; term suggester 是根据某词元在制定的字段中出现的频次来做出提示; phrase suggester 是给term 上做了加强; 这里不做使用方法介绍;

链接地址:http://www.elasticsearch.org/guide/en/elasticsearch/reference/current/search-suggesters-term.html

剩下的是completion 、context suggester。 这两个的使用与上面个使用方法完全不一样,上面都在查询的时候根据制定字段内容来做提示,而这两种是需要在mapping 里面定制suggester字段。使用时完全匹配时提示;

completion suggester 官方文档 http://www.elasticsearch.org/guide/en/elasticsearch/reference/current/search-suggesters-completion.html 文档讲解的非常全面,遗憾的是没有代码,这里把代码加上java client;

1:设置mapping 中的suggester

@Test 
public void createQucikIndecs() throws IOException{ 
XContentBuilder mapping = XContentFactory.jsonBuilder() 
.startObject() 
.startObject("pingzhuang") 
.startObject("properties") 
.startObject("id").field("type", "long").field("store", "yes").field("index", "not_analyzed").endObject() 
.startObject("name").field("type", "string").field("store", "no").field("indexAnalyzer", "ik").field("searchAnalyzer", "ik").endObject() 
.startObject("suggest").field("type","completion").field("index_analyzer","simple").field("search_analyzer","simple").field("payloads","true").endObject() 
.endObject() 
.endObject() 
.endObject(); 
ESHandler.createQuickIndices("chinamedic", "pingzhuang", mapping, "formedic"); 
}

2: 设置好了以后,在做索引的时候每次都应该添加提示

@Test 
public void addIndex(){ 
String json="{\"id\":44,\"name\":\"老狼-白衣飘飘的年代\",\"suggest\":{\"input\":\"老狼-白衣飘飘的年代\"}}"; 
String json1="{\"id\":42,\"name\":\"老狼-郎心似铁\",\"suggest\":{\"input\":\"老狼-郎心似铁\"}}"; 
String json2="{\"id\":43,\"name\":\"老狼-流浪歌手的请人\",\"suggest\":{\"input\":\"老狼-流浪歌手的请人\"}}"; 
ESHandler.addOneIndex("chinamedic","pingzhuang", json); 
ESHandler.addOneIndex("chinamedic","pingzhuang", json1); 
ESHandler.addOneIndex("chinamedic","pingzhuang", json2); 
System.out.println(); 
}

3: 然后就是查询获得提示了

/** 
* 搜索建议,自动补全搜索结结果 
* @param indices 索引库名称 
* @param prefix 搜索前缀词 
* @return 建议列表 
*/ 
public static List<String> getCompletionSuggest(String indices, 
String prefix) { 
CompletionSuggestionBuilder suggestionsBuilder = new CompletionSuggestionBuilder( 
"complete"); 
suggestionsBuilder.text(prefix); 
suggestionsBuilder.field("suggest"); 
suggestionsBuilder.size(10); 
SuggestResponse resp = client.prepareSuggest(indices) 
.addSuggestion(suggestionsBuilder).execute().actionGet(); 
List<? extends Entry<? extends Option>> list = resp.getSuggest() 
.getSuggestion("complete").getEntries(); 
List<String> suggests = new ArrayList<String>(); 
if (list == null) { 
return null; 
} else { 
for (Entry<? extends Option> e : list) { 
for (Option option : e) { 
suggests.add(option.getText().toString()); 
} 
} 
return suggests; 
} 
}

ok,到这里一个简单的completion suggester 就完成了。

后续再添加更多高级的使用示例。

elasticsearch suggest 的几种使用-completion 使用,布布扣,bubuko.com

elasticsearch suggest 的几种使用-completion 使用

标签:Lucene   blog   http   java   使用   os   

原文地址:http://www.cnblogs.com/jiuyuehe/p/3840821.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!