利用redis完成自动补全搜索功能(三)
前面已经完成了分词和自动提示功能,最后把搜索结合在一起,来个完成的案例。当然最好还是用搜索分词解决,这个只是一个临时解决方案。
其实加上搜索很简单,要做的就是3件事
1. 分词的时候,把有用词的id存进hash.
2. 每次搜索的关键词,如果存在的自增
3. 通过关键词把hash里的 id取出,然后通过id查询数据库即可。
dist.php 分词
<?php
require './redis.php'; //从数据库取出需要分词的数据
$words = [
['name'=>'花讯','id'=>1],
['name'=>'nba','id'=>2],
['name'=>'nba直播','id'=>3],
['name'=>'nba赛事','id'=>4],
['name'=>'nba季后赛','id'=>5],
['name'=>'nba录像','id'=>6],
['name'=>'花讯品牌','id'=>7],
['name'=>'花讯女装','id'=>8],
['name'=>'花','id'=>9],
['name'=>'n','id'=>10],
['name'=>'nba直播','id'=>11],
]; //利用管道
Cache::getInstance()->pipeline();
foreach ($words as $val) { $len = mb_strlen($val['name'],'utf-8');
for ($i=0;$i<=$len;$i++){ $key = mb_substr($val['name'],0,$i+1,'utf-8');
if ($i == $len) {
//所有相同关键词id
$arr[$key][] = $val['id']; $key .= '*';
//初始化关键词搜索次数
Cache::getInstance()->hSet("search:hits",$key,0);
}
//分词加入有序集合
Cache::getInstance()->zAdd('search',0,$key);
} }
Cache::getInstance()->exec();
unset($words); //生成有用关键词hash表,用来存储id
if (!empty($arr)) {
array_walk($arr,function(&$v,$k){
$v = join(',',$v);
});
Cache::getInstance()->hMset("search:ids",$arr);
} echo 'ok';
search.php
<?php
require './redis.php'; $key = isset($_GET['key']) ? $_GET['key'] : 'nba直' ; //如果存在 自增1
if (Cache::getInstance()->hGet("search:hits","{$key}*") !== false)
Cache::getInstance()->hIncrBy("search:hits","{$key}*",1); //关键字开头存在有序集合的位置
$index = Cache::getInstance()->zRank('search',$key);
if ($index === false)
goto END; if ($_res = Cache::getInstance()->zRange('search',$index,-1)){ foreach ($_res as $val){
if (strpos($val,$key) === 0 && strrev($val)[0] == '*'){
$arr[] = substr($val,0,-1);
}
}
//从hash表中获取id
$res = Cache::getInstance()->hMGet("search:ids",$arr); //通过id 从mysql 获取数据源
echo 'ok';
} END:
4. 前端ajax请求获取数据渲染模板
完整代码: http://files.cnblogs.com/files/loveyouyou616/search.zip
利用redis完成自动补全搜索功能(三)的更多相关文章
- 利用redis完成自动补全搜索功能(一)
最近要做一个搜索自动补全的功能(目前只要求做最前匹配),自动补全就是自动提示,类似于搜索引擎,再上面输入一个字符,下面会提示多个关键词供参考,比如你输入 nb 2字符, 会自动提示nba,nba录像, ...
- 利用redis完成自动补全搜索功能(二)
前面介绍了自动完成的大致思路,现在把搜索次数的功能也结合上去.我采用的是hash表来做的,当然也可以在生成分词的时候,另外一个有序集合来维护排序, 然后2个有序集合取交集即可.这里介绍hash的方式来 ...
- C++ tab键实现自动补全输入功能
一.简介 由于项目中写了个测试的控制台程序,是每次读取一行,即通过getline()来实现的,所以每次必须输入全路径名称,才能实现运行. 大家都觉得麻烦,就写了个tab键自动选择补全的. 目前基本可实 ...
- linux下让irb实现代码自动补全的功能
我不知道其他系统上irb是否有此功能,但是在ubuntu上ruby2.1.2自带的irb默认是没有代码自动补全功能的,这多少让人觉得有所不便.其实加上也很简单,就是在irb里加载一个模块:requir ...
- 各大搜索引擎智能提示API(JSONP跨域实现自动补全搜索建议)
---------------------------------------搜索引擎JSONP接口--------------------------------------------- 提示:U ...
- 使用Redis实现中英文自动补全功能详解
1.Redis自动补全功能介绍: Redis可以帮我们实现很多种功能,今天这里着重介绍的是Redis的自动补全功能的实现.我们使用有序集合,并score都为0,这样就按元素值的字典序排序.然后我们 ...
- Visual Studio Code使用typings拓展自动补全功能
转自:http://blog.csdn.net/liyijun4114/article/details/51658087 参考来源: 官方介绍: https://code.visualstudio.c ...
- Eclipse 自动补全功能失效解决办法及修改快捷键方法
最近在学习Java,前段时间分盘把电脑能坏了,重装系统后发现我的Eclipse的自动补全的功能失效了,那多麻烦呀,什么都得自己打,于是百度后总结了以下解决方法: 1.点击Window-->Pre ...
- Shell脚本中实现自动补全功能
对于Linuxer来说,自动补全是再熟悉不过的一个功能了.当你在命令行敲下部分的命令时,肯定会本能地按下Tab键补全完整的命令,当然除了命令补全之外,还有文件名补全. Bash-completion ...
随机推荐
- Spark SQL 编程
Spark SQL的依赖 Spark SQL的入口:SQLContext 官方网站参考 https://spark.apache.org/docs/1.6.2/sql-programming-guid ...
- django-重写User模型
User模型有很多功能,验证什么的,重写需要满足下面的功能(基本上写注释的地方都是需要的) 开始: 创建一个重写user的app, 记得注册app startapp newauth from djan ...
- 最小生成树-kruskal
kruskal算法,没有进行算法复杂度分析 判断俩个结点是否在同一个树上使用了dfs,比较low的写法 输入数据 //第一行,结点数,结点数,边数 9 9 14a b 4b c 8c d 7a h 8 ...
- c# 导入导出excel表格式
c#使用代码导入excel时,当遇到纯数字且大于15位时会出现编码混乱(表现为科学计数法),要想呈现与excel表中纯数字格式和在数据库中呈现纯数字,操作如下: 完成即可. 导出取决于导入的内容排版.
- OpenACC 计算圆周率(简单版)
▶ 书上的计算圆周率的简单程序,主要是使用了自定义函数 #include <stdio.h> #include <stdlib.h> #include <math.h&g ...
- div+css样式命名规则,值得收藏
div+css样式命名规则,值得收藏 头:header 内容:content/container 尾:footer 导航:nav 侧栏:sidebar 栏目:column 页面外围控制整体布局宽度:w ...
- Delphi RAD Berlin OutputDebugString 输出调试信息
Delphi RAD Berlin Event Log.OutputDebugString 输出调试信息,仅在win VCL下可以用.OutputDebugString(PChar('hellowor ...
- 调用css文件,进行调色
Title 小米 <!DOCTYPE html> <html lang="en"> <head> <meta charset= ...
- Reactjs 打包后 Tomcat 部署 404问题
配置web.xml <error-page> <error-code>404</error-code> <location>/index.html< ...
- 基于OpenGL编写一个简易的2D渲染框架-03 渲染基本几何图形
阅读文章前需要了解的知识,你好,三角形:https://learnopengl-cn.github.io/01%20Getting%20started/04%20Hello%20Triangle/ 要 ...