淘先锋技术网

首页 1 2 3 4 5 6 7

背景: 在很多商城中的商品搜索结果页中,有显示"猜你喜欢"的商品如图(1),这些数据需要根据当前的搜索条件查找出相似的商品


                   图(1)

目的:通过solr查找出与当前搜索条件相似的商品

1.solr实现方法介绍

       Solr 使用 MoreLikeThisComponent(MLT)和 MoreLikeThisHandler 实现了相似匹配的功能。MLT 要求字段被储存或使用检索词向量,检索词向量以一种以文档为中心的方式储存信息。MLT 通过文档的内容来计算文档中关键词语,然后使用原始查询词语和这些新词语创建一个新的查询。提交新查询就会返回其他查询结果。所有这些都可以用检索词向量来完成:只需将 termVectors="true" 添加到 schema.xml 中的 <field> 声明。

MoreLikeThisComponent 参数:

参数
说明
值域
mlt 在查询时,打开/关闭 MoreLikeThisComponent 的布尔值。 true|false
mlt.count 可选。每一个结果要检索的相似文档数。  > 0
mlt.fl 用于创建 MLT 查询的字段。  任何被储存的或含有检索词向量的字段。
mlt.maxqt

可选。查询词语的最大数量。由于长文档可能会有很多关键词语,这样 MLT 查询可能会很大,

从而导致反应缓慢或可怕的 TooManyClausesException,该参数只保留关键的词语。

> 0

2.开始使用

(1). 在 solrconfig.xml 中配置 MoreLikeThisHandler如图(2):


                                                                     图(2)

(2). 在schema.xml中,将需要创建 MLT 查询的字段的 field上添加 termVector=true 如图(3)。


                                                                   图(3)

(3).在solrj中使用图(4):


                                                              如图(4)