PHP redis實(shí)現(xiàn)超迷你全文檢索
情景: 我們平臺有好多游戲, 運(yùn)營的同事在查詢某一款游戲的時候, 目前使用的是html的select下拉列表的展現(xiàn)形式, 運(yùn)營的同事得一個個去找,然后選中,耗時又費(fèi)眼
效果: 輸入"三國"或者"國三", 將自動列出所有包含"三國"的游戲名字, 輸入不限順序; 例如輸入"殺三國",仍然會將"三國殺"這款游戲找出來
實(shí)現(xiàn): 我用redis的集合+PHP的array_intersect()和mb系列函數(shù), 實(shí)現(xiàn)了一個超迷你的全文檢索功能
原理: (大道不過兩三言,說穿不值一文錢,哈哈)
1、將所有的游戲名字讀出來,拆分成單個漢字
2、 將這些漢字作為redis集合的鍵,寫入redis,每個集合里的值是所有那些游戲名字中包含此漢字的游戲的id
3、當(dāng)用戶輸入文字的時候通過ajax異步請求,將用戶輸入傳給PHP
4、將輸入的文字拆分成單個漢字, 分別找到這些漢字在redis中的集合值
5、取出來,求交集,就找到了同時包含這幾個漢字的游戲的id
6、最后到數(shù)據(jù)庫里查出來相應(yīng)的游戲信息即可
缺點(diǎn): 刪除數(shù)據(jù)不方便
PHP寫入redis和檢索的代碼:
//自動補(bǔ)全
//不限輸入漢字的前后順序: 輸入"國三殺" => 輸出 "三國殺"
function getAutoComplate()
{
//$word = $this->input->post('word');
$word = '三國';
if (empty($word)) {
exit('0');
}
$intWordLength = mb_strlen($word, 'UTF-8');
$this->load->library('iredis');
if (1 == $intWordLength) {
$arrGid = $this->iredis->getAutoComplate($word);
} else {
$arrGid = array();
for ($i=0; $i < $intWordLength; $i++) {
$strOne = mb_substr($word, $i, 1, 'UTF-8');
$arrGidTmp = $this->iredis->getAutoComplate($strOne);
$arrGid = empty($arrGid) ? $arrGidTmp : array_intersect($arrGid, $arrGidTmp); //求交集,因?yàn)閭魅氲膮?shù)個數(shù)不確定,因此不能直接求交集
}
}
$arrGame = $this->gamemodel->getGameNameForAutoComplate($arrGid);
// var_dump($arrGame);exit;
$jsonGame = json_encode($arrGame);
exit($jsonGame);
}
//自動補(bǔ)全, 建立索引
function setAutoComplate()
{
$arrGame = $this->gamemodel->getAllGameNameForAutoComplate();
$arrIndex = array();
foreach ($arrGame as $gid => $gname) {
$intGnameLength = mb_strlen($gname, 'UTF-8');
for ($i=0; $i < $intGnameLength; $i++) {
$strOne = mb_substr($gname, $i, 1, 'UTF-8');
$arrIndex[$strOne][] = $gid;
}
}
$this->load->library('iredis');
foreach ($arrIndex as $word => $arrGid) {
foreach ($arrGid as $gid) {
$this->iredis->setAutoComplate($word, $gid);
}
}
}
操作redis的方法
//自動補(bǔ)全功能
public function setAutoComplate($key, $value)
{
$youxikey = 'youxi_'.$key;
$this->sAdd($youxikey, $value);
}
//自動補(bǔ)全功能
public function getAutoComplate($key)
{
$youxikey = 'youxi_'.$key;
return $this->sMembers($youxikey);
}
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- centos+php+coreseek+sphinx+mysql之一coreseek安裝篇
- php啟用sphinx全文搜索的實(shí)現(xiàn)方法
- 深入解析php之sphinx
- 開源php中文分詞系統(tǒng)SCWS安裝和使用實(shí)例
- php利用scws實(shí)現(xiàn)mysql全文搜索功能的方法
- php實(shí)現(xiàn)scws中文分詞搜索的方法
- php mysql like 實(shí)現(xiàn)多關(guān)鍵詞搜索的方法
- PHP實(shí)現(xiàn)從PostgreSQL數(shù)據(jù)庫檢索數(shù)據(jù)分頁顯示及根據(jù)條件查找數(shù)據(jù)示例
- PHP中檢索字符串的方法分析【strstr與substr_count方法】
- PHP+sqlite數(shù)據(jù)庫操作示例(創(chuàng)建/打開/插入/檢索)
- PHP+MySQL+sphinx+scws實(shí)現(xiàn)全文檢索功能詳解
相關(guān)文章
Yii CDBCriteria常用方法實(shí)例小結(jié)
這篇文章主要介紹了Yii CDBCriteria常用方法,結(jié)合實(shí)例形式總結(jié)分析了CDBCriteria類的功能與常用方法,具有一定參考借鑒價值,需要的朋友可以參考下2017-01-01
PHP下用Swoole實(shí)現(xiàn)Actor并發(fā)模型的方法
這篇文章主要介紹了PHP下用Swoole實(shí)現(xiàn)Actor并發(fā)模型的方法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-06-06
php簡單實(shí)現(xiàn)屏蔽指定ip段用戶的訪問
這里給大家分享的是一個簡單的使用php實(shí)現(xiàn)的屏蔽指定IP段的代碼,非常的實(shí)用,有需要的小伙伴可以參考下。2015-04-04
thinkphp視圖模型查詢提示ERR: 1146:Table ''db.pr_order_view'' doesn''
這篇文章主要介紹了thinkphp視圖模型查詢提示ERR: 1146:Table 'db.pr_order_view' doesn't exist的解決方法,對于ThinkPHP初學(xué)者來說有一定的借鑒價值,需要的朋友可以參考下2014-10-10
利用phpexcel把excel導(dǎo)入數(shù)據(jù)庫和數(shù)據(jù)庫導(dǎo)出excel實(shí)現(xiàn)
本文介紹利用phpexcel對數(shù)據(jù)庫數(shù)據(jù)導(dǎo)入excel(excel篩選)、導(dǎo)出excel,大家參考使用吧2014-01-01
PHP登錄(ajax提交數(shù)據(jù)和后臺校驗(yàn))實(shí)例分享
本文主要分享了PHP登錄(ajax提交數(shù)據(jù)和后臺校驗(yàn))的實(shí)例代碼,具有一定的參考價值,下面跟著小編一起來看下吧2016-12-12

