sphinx安装,配置,使用,分页

  1. Sphinx简介

SQL   结构化查询语言(是一种标准,所有的关系型数据库Mysql,sqlserver,oracle)

sphinx的使用两种方式:

第一种:  使用sphinx的API来操作sphinx   (常用)

sphinx可以使用API类,也可以将api编译到PHP中做为扩展

第二种:  使用mysql的sphinx的存储引擎

sphinx  这是英文的全文检索引擎

coreseek  这是支持中文词库的全文检索引擎

区别:

英文的文章 怎么能区分哪个词    以空格来区分词的

中文的文章 我爱北京天安门      中文词库

使用sphinx的步骤:

2、sphinx配置(配置文件 csft_mysql.conf)

配置文件格式

1、数据源定义 (指向你数据的来源 ,通常是mysql)

2、索引 (索引的一些配置信息)

3、indexer  (内用的内存---基本不需要设置)

4、searchd  (服务器的一些配置---)

注意:

1、一个配置文件可以配置多个数据源和索引 ((1,2),(1,2),nnnn)

2、sql_query  主查询(把数据库表中的哪些字段查询出来--根据你页面的搜索条件)

select 第一个字段(一定是主键)

3. sphinx安装

① cd E:/usr/local/coreseek-3.2.14-win32

② indexer.exe -c 配置文件 --all(参数--all 表示创建全部索引)

.\bin\indexer.exe -c .\etc\csft_mysql.conf --all

③ 启动searchd 服务  searchd.exe -c 配置文件

.\bin\searchd.exe -c .\etc\csft_mysql.conf  如果启动服务出现1067错误后 查看配置文件 和配置文件的文字编码

④ php 操作sphinx

  1. Sphinx 的使用

use SphinxClient;

/*引入sphinx类*/

Yii::$classMap['SphinxClient']="@vendor/sphinx/sphinxapi.php";

//简单使用sphinx

$cl = new SphinxClient ();

$cl->SetServer ( '127.0.0.1', 9312);

$cl->SetMatchMode ( SPH_MATCH_ALL); //匹配格式  任意匹配

SPH_MATCH_ALL匹配所有查询词(默认模式)
SPH_MATCH_ANY匹配查询词中的任意一个
SPH_MATCH_PHRASE将整个查询看作一个词组,要求按顺序完整匹配
SPH_MATCH_BOOLEAN将查询看作一个布尔表达式
SPH_MATCH_EXTENDED将查询看作一个Sphinx内部查询语言的表达式
SPH_MATCH_FULLSCAN使用完全扫描,忽略查询词汇
SPH_MATCH_EXTENDED2类似 SPH_MATCH_EXTENDED ,并支持评分和权重.

$cl->SetArrayResult ( true );  //作为数组返回

$cl->SetMaxQueryTime(10); //设置最大搜索时长

//$cl->SetFilter('cat_id', array(1));//过滤条件

$cl->setSortMode(SPH_SORT_EXTENDED,'@id desc'); //排序

//$res=$cl->Query ( $req, "*" ); //执行搜索

$res=$cl->Query($req, '*');//搜索全部

  1. Sphinx 标红

$opt=array("before_match"=>"<font style='font-weight:bold;color:#f00'>","after_match"=>"</font>");

//这里为sphinx高亮显示

foreach($data_arr as $k=>$v){

$rows = $cl->buildExcerpts($v,"mysql",$req,$opt);

$model_arr[$k]['id']=$rows[0];

$model_arr[$k]['name']=$rows[1];

$model_arr[$k]['cat_id']=$rows[2];

}

【注意】:

语法:public array SphinxClient::buildExcerpts ( array $docs , string $index , string $words [, array $opt ] )

可以有四个参数,前三个为必须

array $docs    :     即从数据库取出来的结果数组(fetch_assoc),本实例为 $row ;

string $Index   :    即我们在csft_mysql.conf 配置的索引名,本实例为 news

string $words  :    搜索的关键词,本实例为 $keyword

可选参数 array $opts:它是一个索引数组,你可以定义其中的一些单元,

php--sphinx的使用的更多相关文章

  1. 利用sphinx为python项目生成API文档

    sphinx可以根据python的注释生成可以查找的api文档,简单记录了下步骤 1:安装 pip install -U Sphinx 2:在需要生成文档的.py文件目录下执行sphinx-apido ...

  2. 安装PHP sphinx扩展 sphinx-1.1.0/sphinx.c:105:2: error: too few arguments 错误

    表现: /home/sphinx-1.1.0/sphinx.c: In function 'php_sphinx_client_read_property':/home/sphinx-1.1.0/sp ...

  3. 【整理】Linux下中文检索引擎coreseek4安装,以及PHP使用sphinx的三种方式(sphinxapi,sphinx的php扩展,SphinxSe作为mysql存储引擎)

          一,软件准备 coreseek4.1 (包含coreseek测试版和mmseg最新版本,以及测试数据包[内置中文分词与搜索.单字切分.mysql数据源.python数据源.RT实时索引等测 ...

  4. coreseek+sphinx+mysql+thinkphp整合

    1.安装coreseek 1.1首先升级或安装系统依赖库 yum install make gcc g++ automake libtool mysql-client libmysqlclient15 ...

  5. 全文检索解决方案(lucene工具类以及sphinx相关资料)

    介绍两种全文检索的技术. 1.  lucene+ 中文分词(IK) 关于lucene的原理,在这里可以得到很好的学习. http://www.blogjava.net/zhyiwww/archive/ ...

  6. 如何将Sphinx生成的html文档集成进入Django

    参考 http://stackoverflow.com/questions/10594618/django-and-sphinx-how-to-view-the-html-sphinx-generat ...

  7. Linux下搭建coreseek(sphinx+mmseg3)全文检索

    测试平台:Center OS 1.设置环境,升级/安装系统基础依赖包:m4.autoconf.automake.libtool #设置路径和中文环境: $ export PATH=/usr/local ...

  8. debian下使用Sphinx异常“Could not import extension sphinx.builders.linkcheck (exception: cannot import name SSLError)”的解决

    最近使用到Sphinx编译文档,出现如下异常: Extension error:Could not import extension sphinx.builders.linkcheck (except ...

  9. [搜索引擎]Sphinx的介绍和原理探索

    What/Sphinx是什么 定义 Sphinx是一个全文检索引擎. 特性 索引和性能优异 易于集成SQL和XML数据源,并可使用SphinxAPI.SphinxQL或者SphinxSE搜索接口 易于 ...

  10. Sphinx安装配置应用

    Sphinx 是由俄罗斯人Andrew Aksyonoff开发的一个全文搜索引擎.意图为其他应用提供高速.地空间占用.高结果相关度的全文搜索功能.Sphinx可以非常容易的与SQL数据库和脚本语言集成 ...

随机推荐

  1. LightOJ1157 LCS Revisited(DP)

    题目求两个字符串s1,s2不同的LCS个数. 经典的求LCS的DP是这样的: LCS[i][j]表示s1[0...i]和s2[0...j]的LCS LCS[i][j]从LCS[i-1][j-1]+1( ...

  2. BZOJ1525 : [POI2006]Zos

    由于k很小,所以随机一组解的正确率有90%以上. 每次随机选取一个没被删除的点,然后将与其相邻的点都删去即可. #include<cstdio> #include<cstdlib&g ...

  3. weblogic sockets 和 thread 问题解决

    原创文章,转载须注明出处. 这个问题网上很多答案,可惜没一个能解决.后来发现是weblogic 必须适配JDK 版本. 一般会报这个错误,There are: 5 active sockets, bu ...

  4. oracle在线重定义表

    在一个高可用系统中,如果需要改变一个表的定义是一件比较棘手的问题,尤其是对于7×24系统.Oracle提供的基本语法基本可以满足一般性修改,但是对于把普通堆表改为分区表,把索引组织表修改为堆表等操作就 ...

  5. 创建自定义 jQuery 移动主题

    自定义页面.工具栏.内容.表单元素.列表.按钮等元素的外观 智能电话和平板设备的高采用率最终导致增加了对移动 Web 开发人员和设计师的需求.jQuery Mobile 框架支持您创建能与原生应用程序 ...

  6. 绕过杀毒软件抓取windows密码

    使用procdump,由于是微软的东西,带微软签名杀软不会报毒. procdump -accepteula -ma lsass.exe lsass.dmp copy出 lsass.dmp到本机. mi ...

  7. 服务器文件系统一定要用NTFS格式。

    网络中心通过ADSL接入Internet(固定的IP地址), 网站服务通过端口映射放到了内网的两台计算机上,一台IP地址为122.9.6.1,提供Web.FTP.POP3与SMTP服务:另一台IP地址 ...

  8. 连连看beta发布

    组名:天天向上 组长:王森 组员:张政.张金生.林莉.胡丽娜 代码地址:HTTPS:https://git.coding.net/jx8zjs/llk.git SSH:git@git.coding.n ...

  9. ThinkPHP 3.2.2 实现持久登录 ( 记住我 )

    实现持久登录,即用户在登录时,勾选了"记住我"之后,无论是否关闭浏览器,只要不退出登录,在指定的时间内始终保持登录状态(缺点是在另一台电脑上登录过后,之前那台电脑就不能继续保持登录 ...

  10. spring对dao层的支持(datasource的作用)

    本文大多数内容转自“http://www.cnblogs.com/liunanjava/p/4412408.html”感谢原作者 在做一个项目时,持久层并没有使用spring jpa和hibernat ...