PHP+redis實現超迷你全文檢索
2014年10月31日 11:45:39
情景: 我們平臺有好多遊戲, 運營的同事在查詢某一款遊戲的時候, 目前使用的是html的select下拉選單的展現形式, 運營的同事得一個個去找,然後選中,耗時又費眼
效果: 輸入”三國”或者”國三”, 將自動列出所有包含”三國”的遊戲名字, 輸入不限順序; 例如輸入”殺三國”,仍然會將”三國殺”這款遊戲找出來
實現: 我用redis的集合+PHP的array_intersect()和mb系列函式, 實現了一個超迷你的全文檢索功能
原理: (大道不過兩三言,說穿不值一文錢,哈哈)
1, 將所有的遊戲名字讀出來,拆分成單個漢字
2, 將這些漢字作為redis集合的鍵,寫入redis,每個集合裡的值是所有那些遊戲名字中包含此漢字的遊戲的id
3, 當使用者輸入文字的時候通過ajax非同步請求,將使用者輸入傳給PHP
4, 將輸入的文字拆分成單個漢字, 分別找到這些漢字在redis中的集合值
5, 取出來,求交集,就找到了同時包含這幾個漢字的遊戲的id
6, 最後到資料庫裡查出來相應的遊戲資訊即可
缺點: 刪除資料不方便
PHP寫入redis和檢索的程式碼:
1 //自動補全 2 //不限輸入漢字的前後順序: 輸入"國三殺" => 輸出 "三國殺" 3 function getAutoComplate() 4 { 5 //$word = $this->input->post(`word`); 6 $word = `三國`; 7 if (empty($word)) { 8 exit(`0`); 9 } 10 $intWordLength = mb_strlen($word, `UTF-8`); 11 12 $this->load->library(`iredis`); 13 if (1 == $intWordLength) { 14 $arrGid = $this->iredis->getAutoComplate($word); 15 } else { 16 $arrGid = array(); 17 for ($i=0; $i < $intWordLength; $i++) { 18 $strOne = mb_substr($word, $i, 1, `UTF-8`); 19 $arrGidTmp = $this->iredis->getAutoComplate($strOne); 20 $arrGid = empty($arrGid) ? $arrGidTmp : array_intersect($arrGid, $arrGidTmp); //求交集,因為傳入的引數個數不確定,因此不能直接求交集 21 } 22 } 23 24 $arrGame = $this->gamemodel->getGameNameForAutoComplate($arrGid); 25 // var_dump($arrGame);exit; 26 $jsonGame = json_encode($arrGame); 27 exit($jsonGame); 28 } 29 30 //自動補全, 建立索引 31 function setAutoComplate() 32 { 33 $arrGame = $this->gamemodel->getAllGameNameForAutoComplate(); 34 $arrIndex = array(); 35 foreach ($arrGame as $gid => $gname) { 36 $intGnameLength = mb_strlen($gname, `UTF-8`); 37 for ($i=0; $i < $intGnameLength; $i++) { 38 $strOne = mb_substr($gname, $i, 1, `UTF-8`); 39 $arrIndex[$strOne][] = $gid; 40 } 41 } 42 43 $this->load->library(`iredis`); 44 foreach ($arrIndex as $word => $arrGid) { 45 foreach ($arrGid as $gid) { 46 $this->iredis->setAutoComplate($word, $gid); 47 } 48 } 49 50 }
操作redis的方法
1 //自動補全功能 2 public function setAutoComplate($key, $value) 3 { 4 $youxikey = `youxi_`.$key; 5 $this->sAdd($youxikey, $value); 6 } 7 8 //自動補全功能 9 public function getAutoComplate($key) 10 { 11 $youxikey = `youxi_`.$key; 12 return $this->sMembers($youxikey); 13 }
相關文章
- 基於ElasticSearch實現商品的全文檢索檢索Elasticsearch
- php + MongoDB + Sphinx 實現全文檢索PHPMongoDB
- ElasticSearch 實現分詞全文檢索 - 概述Elasticsearch分詞
- 配置全文檢索
- ElasticSearch 實現分詞全文檢索 - delete-by-queryElasticsearch分詞delete
- Mysql 如何實現全文檢索,關鍵詞跑分MySql
- 全文檢索庫 bluge
- Kibana 全文檢索操作
- 基於Lucene的全文檢索實踐
- lnmp+coreseek實現站內全文檢索(安裝篇)LNMP
- 全文檢索的轉義
- solr全文檢索學習Solr
- openGauss每日一練(全文檢索)
- oracle全文索引之配置全文檢索環境Oracle索引
- IM全文檢索技術專題(四):微信iOS端的最新全文檢索技術優化實踐iOS優化
- Oracle的全文檢索技術(轉)Oracle
- PostgreSQL全文檢索-詞頻統計SQL
- 全文檢索技術lucene的demo
- 【搜尋引擎】Solr Suggester 實現全文檢索功能-分詞和和自動提示Solr分詞
- php+redis實現超時取消訂單功能PHPRedis
- springboot ElasticSearch 簡單的全文檢索高亮Spring BootElasticsearch
- 【IT老齊072】全文檢索執行原理
- 讀書筆記:從Lucene到Elasticsearch:全文檢索實戰筆記Elasticsearch
- 【搜尋引擎】Solr全文檢索近實時查詢優化Solr優化
- 在ef core中使用postgres資料庫的全文檢索功能實戰資料庫
- 個人部落格分享(Laravel + Vue 元件,支援全文檢索)LaravelVue元件
- 沒辦法了,用 MySQL 做全文檢索也挺好的MySql
- 如何快速實現高併發短文檢索
- php+redis實現延遲佇列PHPRedis佇列
- 在ef core中使用postgres資料庫的全文檢索功能實戰之中文支援資料庫
- Homestead 環境下安裝 Elasticsearch 並使用 scout 進行全文檢索Elasticsearch
- 【搜尋引擎】 PostgreSQL 10 實時全文檢索和分詞、相似搜尋、模糊匹配實現類似Google搜尋自動提示SQL分詞Go
- OpenCV特徵提取與影像檢索實現(附程式碼)OpenCV特徵
- 23個最有用的ES檢索技巧(Java API實現)JavaAPI
- C#實現前向最大匹、字典樹(分詞、檢索)C#分詞
- ES:檢索
- pta檢索
- JavaScript 檢視全文和收起JavaScript
- Docker學習 ,超全文件!Docker