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):
首先定义渲染器和名字:
<queryResponseWriter name="velocity" class="org.apache.solr. request.VelocityResponseWriter"/>
其次定义请求的处理器(包括显示的结果,行数,默认的查询域,查询的格式等等):<requestHandler name="/browse" class="solr.SearchHandler">
<lst name="defaults">
<str name="wt">velocity</str>
<str name="v.template">browse</str>
<str name="v.layout">layout</str>
<str name="title">Solr cookbook example</str>
<str name="defType">dismax</str>
<str name="q.alt">*:*</str>
<str name="rows">10</str>
<str name="fl">*,score</str>
<str name="qf">name</str>
</lst>
</requestHandler>
---------------------------------
匹配相似(moreLikeThis)
他的作用是查找相似的document。
首先在 solrconfig.xml 中配置 MoreLikeThisHandler
<requestHandler name="/mlt" class="solr.MoreLikeThisHandler">
</requestHandler>
然后我就可以请求 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 才有效果
<field name="name" 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(); }