Solr Lucene找到交叉点最多的文档

Solr Lucene找到交叉点最多的文档,solr,lucene,Solr,Lucene,我想在Lucene中实现“共同的朋友”的功能,所以我有很多带有朋友列表的文档 DOC: id: p1 name: Mike profile_id: 1 friends_id: [2,3,4,5,6,7,8] 或 或 如果我是Mike的账户,我想通过Lucene查询找到另一个拥有更多共同朋友的账户。如果可能的话,也可以在响应中添加带有该编号的字段。您可以尝试以下步骤 1) 访问Mike文档的术语向量 2) 访问friends\u id字段中的术语 3) 迭代这些术

我想在Lucene中实现“共同的朋友”的功能,所以我有很多带有朋友列表的文档

DOC:
    id: p1
    name: Mike
    profile_id: 1
    friends_id: [2,3,4,5,6,7,8]


如果我是Mike的账户,我想通过Lucene查询找到另一个拥有更多共同朋友的账户。如果可能的话,也可以在响应中添加带有该编号的字段。

您可以尝试以下步骤

1) 访问Mike文档的术语向量

2) 访问friends\u id字段中的术语

3) 迭代这些术语(即friend_ID)并形成术语查询的布尔查询

4) 使用该查询搜索索引

5) 假设您在friends_id文件中没有重复的条款,它应该可以工作。最好的结果应该符合您的要求

更好的是,Lucene提供了更像此查询的功能,以便为查询中提供的术语实现类似的文档

简而言之,此查询用于查找候选文档的类似文档。它所做的只是上面的步骤。在您的用例中,您不是在为候选文档寻找类似的文档,而是在为文档中的字段寻找顶部的类似文档

下面是的示例代码

id: p3
name: John
profile_id: 3
friends_id: [6,7,8,9,10]
 id: p5
    name: Roftl
    profile_id: 5
    friends_id: [1,2,3,6,10]