donglvlao8367 2017-01-21 18:51
浏览 78
已采纳

为什么Sphinx中的这个查询失败了?

I am using sphinx and in most normal use queries it returns results as expected. One query however refuses to do so. I am using the following query code:

$cl = new SphinxClient();
$cl->SetServer( "localhost", 9312 );
$cl->SetMatchMode( SPH_MATCH_EXTENDED  );
$cl->SetRankingMode ( SPH_RANK_SPH04 );
$q = '"' . $cl->EscapeString($_REQUEST['keyword']) . ' @provider 2"/1';
$result = $cl->Query($q, 'mainIndex' );

The query ends up becoming:

"air compressor @provider 2"/1

Can anyone please explain why this query still returns results from providers with different IDs than '2'?

  • 写回答

1条回答 默认 最新

  • dongqichang7988 2017-01-21 22:12
    关注

    Well the quorum operator, is the 'outermost' operator. All the words inside the quotes, will be words used by it. THe @ wont have any special meaning in there. So the query is the same as

    "air compressor provider 2"/1
    

    Hence, just requiring just one of those 4 words.

    I wonder if you mean to do

    "air compressor"/1 @provider 2
    

    That would just do quorum on the two single keywords, and then the field syntax would work, and require '2' to match the provider.

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?