問題:使用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內部查詢語言的表達式。