我正在使用Sphinx和Symfony2來掃描我的數據庫中的人。
奇怪的行爲是: 我搜索,吉姆,其結果是:
Sphinx搜索錯過成績
- 詹姆斯 '吉姆' 歌手
- 吉姆·亞伯拉罕
- 吉姆·安德森
- 吉姆·巴克斯
- Jim Bennon
- ...
如果我搜索吉姆·JA結果是:
- 詹姆斯 '吉姆' 歌手
- 吉姆·詹森
- 佔渣木殊
- ...
爲什麼我我錯過了「Ja」的結果,如果我只是搜索吉姆J,但我得到所有其他人?
這裏是源和索引碼:
source peopleautocomplete {
sql_query = SELECT id, firstName, lastName, pseudonym FROM Person
sql_attr_string = pseudonym
sql_attr_string = firstName
sql_attr_string = lastName
}
index peopleautocomplete
{
source = peopleautocomplete
path = /var/lib/sphinxsearch/data/peopleautocomplete
docinfo = extern
charset_type = utf-8
min_word_len = 2
enable_star = 1
min_prefix_len = 1
}
而且PHP代碼:
<?php
$q = $request->query->get('q');
$aq = explode(' ', $q);
if (strlen($aq[count($aq) - 1]) < 2) {
$query = $q;
} else {
$query = $q . '*';
}
$result = $this->_getSearchEngine()->searchEx($query, 'peopleautocomplete');
?>
任何想法?