解決coreseek及sphinx查詢結果不全--匹配參數詳解

問題:使用coreseek搜索關鍵詞發現搜索出來數據尚未mysql模糊查詢的數據多。。。問題出在配置的參數上。php

代碼以下:mysql

<?php
require_once('sphinxapi.php');
$key = isset($_GET['keys'])?$_GET['keys']:'一個';
$page = isset($_GET['page'])?$_GET['page']:1;
$limit = $page * 10;
$sphinx = new SphinxClient();
        $sphinx->SetServer("127.0.0.1",XXXX);
        $sphinx->SetMatchMode(SPH_MATCH_ALL);
        $sphinx->SetLimits($limit, 10, 1000);
        $sphinx->SetArrayResult(true);
        $result = $sphinx -> query($key,"search_notes");
echo json_encode($result);

關鍵點在於這裏(以下),設置匹配模式。默認選項是SPH_MATCH_ALL:sql

$sphinx->SetMatchMode(SPH_MATCH_ALL);

 

匹配模式可供選擇的參數及詳解:json

     SPH_MATCH_ALL, 匹配全部查詢詞(默認模式);api

 好比:關鍵詞爲「錢包身份證」,能夠搜索到標題「個人錢包裏有身份證」,可是搜索不到標題「我有錢包」;必須知足匹配全部的分詞。ui

    SPH_MATCH_ANY, 匹配查詢詞中的任意一個;spa

 好比:關鍵詞爲「錢包身份證」,能夠搜索到標題「個人錢包裏有身份證」,也能夠搜索到標題「我有錢包」;知足匹配全部的分詞中的一個便可。code

    SPH_MATCH_PHRASE, 將整個查詢看做一個詞組,要求按順序完整匹配;blog

    好比:關鍵詞爲「錢包身份證」,能夠搜索到標題「我有錢包身份」,搜索不到標題「個人錢包裏有身份證;將關鍵詞做爲總體去搜索,相似於Mysql中的like模糊查詢。it

    SPH_MATCH_BOOLEAN, 將查詢看做一個布爾表達式 ;

    SPH_MATCH_EXTENDED, 將查詢看做一個Sphinx/Coreseek內部查詢語言的表達式。

相關文章
相關標籤/搜索