繁体   English   中英

Sphinx + php,出现意外查询结果的问题

[英]Sphinx + php, issue with unexpected query results

我正在研究一个启用 sphinx (php) 的自动完成字段来查找用户。 我遇到了一些奇怪的情况,其中某些应该返回匹配项的输入没有。

我的用户索引中的字段是:

'fullname',
'username',
'address',
'phone',
'email'

一些一般配置信息:

charset_type = utf-8
enable_star    = 1
min_infix_len  = 3
ignore_chars = U+20

我当前的查询设置如下:

$search = preg_replace('/([^\s]{3,})/', '*$1*', preg_replace('/[^a-z ]/i', '', $search));
$sphinx->SetMatchMode(SPH_MATCH_EXTENDED2);
$sphinx->SetSortMode(SPH_SORT_RELEVANCE);
$matches = $sphinx->Query($search . ' @email company.com', 'users');

该问题与以下搜索参数有关:

John -> returns list of all Johns (GOOD!)
John S -> returns nothing (BAD!)
John St -> returns all John St*'s (GOOD!)

相似地:

Ben -> returns all Ben's (GOOD!)
Ben M -> returns nothing (BAD!)
Ben Ma -> returns nothing (BAD!)
Ben Mar -> returns user with Ben Mar*'s (GOOD!)

最初我认为问题是因为名字和姓氏在索引的不同字段中,但现在我已经将它们合并到全名字段中,我仍然得到完全相同的结果。

目前(通过上面的 preg_replace)我正在包装在 * 中输入的每个单词。 我也试过用 * 包裹整个字符串,

$search = '*' . $search . '*';

但结果不太准确。 除了extended2之外,我已经尝试过其他搜索模式,但都没有运气。 (情况变得更糟)我添加了一个选项来忽略配置中的空格,希望它能更好地选择“John S”之类的东西,但仍然没有运气。

大多数情况下,我只是希望人们能够通过输入名字+姓氏首字母来找到用户。 这是人们尝试查找用户名的一种常见方式,但目前他们不能。

非常感谢任何帮助。 谢谢!

编辑:

在大量搜索中,我发现了这个: http://sphinxsearch.com/forum/view.html?id=5757

似乎在使用空格进行搜索时可能存在一些错误/不一致。 但如果有人有任何想法,请发表评论。 谢谢!

打开部分索引。

环顾四周:min_infix_len min_prefix_len

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM