分享到:

solr找到与查询结果相似的文档

找到与查询结果相似的文档:

http://localhost:8983/solr/select?q=name:edition&mlt=true&mlt.fl=name&mlt.mintf=1&mlt.mindf=1

mlt.fl:按照结果文档的哪一个field求相似。

mlt.mintf:结果文档中的本field的某一个词出现的tf大于此值,才以此词求相似。

mlt.mindf:通上,不过是df。

自定义的显示结果(非xml):

首先定义渲染器和名字:

其次定义请求的处理器(包括显示的结果,行数,默认的查询域,查询的格式等等):

velocity

browse

layout

Solr cookbook example

dismax

*:*

10

*,score

name

---------------------------------

匹配相似(moreLikeThis)

他的作用是查找相似的document。

首先在 solrconfig.xml 中配置 MoreLikeThisHandler

然后我就可以请求 http://localhost:8080/solr/mlt?q=id:7&mlt.true&mlt.fl=name&mlt.mintf=1&mlt.mindf=1

上面请求的意思 查找 id 为 7 的 document ,然后返回与此 document 在 name 字段上相似的其他 document。需要注意的是 mlt.fl 中的 field 的 termVector=true 才有效果

当然 mlt.fl 也可以添加多个field ,用逗号隔开就行了

 

//相关搜索查询
		List relationList = new ArrayList();
		query = new SolrQuery();
		query.setQuery("title:"+ query_char.toString()+" AND type:2222");  
	        query.addField("title");  
	        query.setStart(0);  
	        query.setRows(10);
	        query.setParam("mlt", "true");
	        query.setParam("mlt.fl", "title");
	        query.setParam("mlt.mintf", "100");
	        query.setParam("mlt.mindf", "1");
	        try {
				QueryResponse response = server.query(query);
				SolrDocumentList docs = response.getResults();
				for (SolrDocument doc : docs) {
					Snaphost host = new Snaphost();
					System.out.println(doc.getFieldValue("title").toString());
					host.setKeyword(doc.getFieldValue("title").toString());
					relationList.add(host);
				}
			} catch (SolrServerException e) {
				e.printStackTrace();
			}