侯体宗的博客
  • 首页
  • Hyperf版
  • beego仿版
  • 人生(杂谈)
  • 技术
  • 关于我
  • 更多分类
    • 文件下载
    • 文字修仙
    • 中国象棋ai
    • 群聊
    • 九宫格抽奖
    • 拼图
    • 消消乐
    • 相册

PHP redis实现超迷你全文检索

Redis  /  管理员 发布于 5年前   472

情景: 我们平台有好多游戏, 运营的同事在查询某一款游戏的时候, 目前使用的是html的select下拉列表的展现形式, 运营的同事得一个个去找,然后选中,耗时又费眼

效果: 输入"三国"或者"国三", 将自动列出所有包含"三国"的游戏名字, 输入不限顺序; 例如输入"杀三国",仍然会将"三国杀"这款游戏找出来

实现: 我用redis的集合+PHP的array_intersect()和mb系列函数, 实现了一个超迷你的全文检索功能

原理: (大道不过两三言,说穿不值一文钱,哈哈)

1、将所有的游戏名字读出来,拆分成单个汉字

2、 将这些汉字作为redis集合的键,写入redis,每个集合里的值是所有那些游戏名字中包含此汉字的游戏的id

3、当用户输入文字的时候通过ajax异步请求,将用户输入传给PHP

4、将输入的文字拆分成单个汉字, 分别找到这些汉字在redis中的集合值

5、取出来,求交集,就找到了同时包含这几个汉字的游戏的id

6、最后到数据库里查出来相应的游戏信息即可

缺点: 删除数据不方便

PHP写入redis和检索的代码:

//自动补全  //不限输入汉字的前后顺序: 输入"国三杀" => 输出 "三国杀"  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); //求交集,因为传入的参数个数不确定,因此不能直接求交集      }    }    $arrGame = $this->gamemodel->getGameNameForAutoComplate($arrGid);    // var_dump($arrGame);exit;    $jsonGame = json_encode($arrGame);    exit($jsonGame);  }  //自动补全, 建立索引  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的方法

//自动补全功能  public function setAutoComplate($key, $value)  {    $youxikey = 'youxi_'.$key;    $this->sAdd($youxikey, $value);  }  //自动补全功能  public function getAutoComplate($key)  {    $youxikey = 'youxi_'.$key;    return $this->sMembers($youxikey);  }

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。

您可能感兴趣的文章:

  • centos+php+coreseek+sphinx+mysql之一coreseek安装篇
  • php启用sphinx全文搜索的实现方法
  • 深入解析php之sphinx
  • 开源php中文分词系统SCWS安装和使用实例
  • php利用scws实现mysql全文搜索功能的方法
  • php实现scws中文分词搜索的方法
  • php mysql like 实现多关键词搜索的方法
  • PHP实现从PostgreSQL数据库检索数据分页显示及根据条件查找数据示例
  • PHP中检索字符串的方法分析【strstr与substr_count方法】
  • PHP+sqlite数据库操作示例(创建/打开/插入/检索)
  • PHP+MySQL+sphinx+scws实现全文检索功能详解


  • 上一条:
    php redis实现对200w用户的即时推送
    下一条:
    php redis实现文章发布系统(用户投票系统)
  • 昵称:

    邮箱:

    0条评论 (评论内容有缓存机制,请悉知!)
    最新最热
    • 分类目录
    • 人生(杂谈)
    • 技术
    • linux
    • Java
    • php
    • 框架(架构)
    • 前端
    • ThinkPHP
    • 数据库
    • 微信(小程序)
    • Laravel
    • Redis
    • Docker
    • Go
    • swoole
    • Windows
    • Python
    • 苹果(mac/ios)
    • 相关文章
    • 在Redis中能实现的功能、常见应用介绍(0个评论)
    • 2024年Redis面试题之一(0个评论)
    • 在redis缓存常见出错及解决方案(0个评论)
    • 在redis中三种特殊数据类型:地理位置、基数(cardinality)估计、位图(Bitmap)使用场景介绍浅析(2个评论)
    • Redis 删除 key用 del 和 unlink 有啥区别?(1个评论)
    • 近期文章
    • 在go中实现一个常用的先进先出的缓存淘汰算法示例代码(0个评论)
    • 在go+gin中使用"github.com/skip2/go-qrcode"实现url转二维码功能(0个评论)
    • 在go语言中使用api.geonames.org接口实现根据国际邮政编码获取地址信息功能(1个评论)
    • 在go语言中使用github.com/signintech/gopdf实现生成pdf分页文件功能(0个评论)
    • gmail发邮件报错:534 5.7.9 Application-specific password required...解决方案(0个评论)
    • 欧盟关于强迫劳动的规定的官方举报渠道及官方举报网站(0个评论)
    • 在go语言中使用github.com/signintech/gopdf实现生成pdf文件功能(0个评论)
    • Laravel从Accel获得5700万美元A轮融资(0个评论)
    • 在go + gin中gorm实现指定搜索/区间搜索分页列表功能接口实例(0个评论)
    • 在go语言中实现IP/CIDR的ip和netmask互转及IP段形式互转及ip是否存在IP/CIDR(0个评论)
    • 近期评论
    • 122 在

      学历:一种延缓就业设计,生活需求下的权衡之选中评论 工作几年后,报名考研了,到现在还没认真学习备考,迷茫中。作为一名北漂互联网打工人..
    • 123 在

      Clash for Windows作者删库跑路了,github已404中评论 按理说只要你在国内,所有的流量进出都在监控范围内,不管你怎么隐藏也没用,想搞你分..
    • 原梓番博客 在

      在Laravel框架中使用模型Model分表最简单的方法中评论 好久好久都没看友情链接申请了,今天刚看,已经添加。..
    • 博主 在

      佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 @1111老铁这个不行了,可以看看近期评论的其他文章..
    • 1111 在

      佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 网站不能打开,博主百忙中能否发个APP下载链接,佛跳墙或极光..
    • 2017-12
    • 2020-03
    • 2020-05
    • 2021-04
    • 2022-03
    • 2022-05
    • 2022-08
    • 2023-02
    • 2023-04
    • 2023-07
    • 2024-01
    • 2024-02
    Top

    Copyright·© 2019 侯体宗版权所有· 粤ICP备20027696号 PHP交流群

    侯体宗的博客