sphinx(七)sphinx匹配模式

简介: Sphinx匹配模式语法: $sp -> SetMatchMode(常量)SPH_MATCH_ALL 匹配所有词(默认)SPH_MATCH_ANY 匹配一个词SPH_MATCH_PHRASE 匹配整一个词SPH_MATCH_BOOLEAN 将查询看作一个布尔表达式SPH_MATCH_EXTENDED 查询看做一个sphinx的表达式

QQ图片20220425162927.jpg

Sphinx匹配模式


语法: $sp -> SetMatchMode(常量)


SPH_MATCH_ALL            匹配所有词(默认)
SPH_MATCH_ANY            匹配一个词
SPH_MATCH_PHRASE     匹配整一个词
SPH_MATCH_BOOLEAN   将查询看作一个布尔表达式
SPH_MATCH_EXTENDED  查询看做一个sphinx的表达式


举例: 我喜欢PHP


分词: 我 喜欢 PHP


准备工作: 先停止服务-> 创建索引->启动服务


1:匹配所有词(SPH_MATCH_ALL)


说明:我 喜欢 PHP 字段都要存在, 位置不限


<?php
#步骤1:引入sphinx接口文件
require './sphinxapi.php';
#步骤2:实例化对象
$sp = new SphinxClient;
#步骤3:设置服务
$sp->SetServer('localhost', 9312);
#步骤4:设置匹配模式
$sp->SetMatchMode(SPH_MATCH_ALL);
#步骤5:设置查询条数
$sp->SetLimits(0, 5000);
#步骤6:发送查询
$rs = $sp->query('我喜欢PHP', 'music');
echo '<pre>';
print_r($rs); #


2:匹配一个词(SPH_MATCH_ANY)


说明: 我 喜欢 PHP 只要有一个存在,就匹配


#步骤4:设置匹配模式
$sp->SetMatchMode(SPH_MATCH_ANY);


3:匹配整个词(SPH_MATCH_PHRASE)


说明: 我 喜欢 PHP 都必须存在 位置必须一致


#步骤4:设置匹配模式
$sp->SetMatchMode(SPH_MATCH_PHRASE);


4:将查询看作一个布尔表达式(SPH_MATCH_BOOLEAN)


#步骤4:设置匹配模式
$sp->SetMatchMode(SPH_MATCH_BOOLEAN);


5:查询看做一个sphinx的表达式(SPH_MATCH_EXTENDED)


说明: 查询指定字段的内容 @字段 内容


举例: @title 内容 @content 内容 @author 内容


#步骤4:设置匹配模式
$sp->SetMatchMode(SPH_MATCH_EXTENDED);
#步骤5:设置查询条数
$sp->SetLimits(0, 5000);
#步骤6:发送查询
$rs = $sp->query('@content PHP @author 校长'); #内容=PHP并作者=校长
echo '<pre>';
print_r($rs); #


这里需要注意一下:


官方的sphinxapi.php中设置查询模式的代码如下所示:


/// set matching mode
    function SetMatchMode ( $mode )
{
// trigger_error 应该注释,否则访问即报错
        trigger_error ( 'DEPRECATED: Do not call this method or, even better, use SphinxQL instead of an API', E_USER_DEPRECATED );
        assert ( $mode==SPH_MATCH_ALL
            || $mode==SPH_MATCH_ANY
            || $mode==SPH_MATCH_PHRASE
            || $mode==SPH_MATCH_BOOLEAN
            || $mode==SPH_MATCH_EXTENDED
            || $mode==SPH_MATCH_FULLSCAN
            || $mode==SPH_MATCH_EXTENDED2 );
        $this->_mode = $mode;
    }


我们需要将trigger_error这行代码注释。否则访问就报错。


这里大概解释一下相关操作符的使用方法:


操作符OR:hello | world,区配含有hello或world


操作符NOT:hello -world或hello !world,区配包含hello,且不包含world


字段搜索操作符:@title hello @body world,匹配title中有hello及body中有world


字段限位修饰符:@title[5] hello ,匹配title字段前5个词中包含有hello


多字段搜索符:@(title,body) hello,匹配title或body包含有hello


全字段搜索符:@* hello,区配任何一列包含有hello


阀值匹配符:"this is test document number"/3,匹配至少包含有3个词


短语(phrase)搜索符:“hello world”


临近(proximity)搜索符:“hello world”~10,匹配hello与world之间小于10个词


严格有序搜索符:aaa<<bbb<<ccc,匹配aaa,bbb,ccc按顺序出现


字段开始和字段结束修饰符:^hello world$,匹配以hello开始,world为结尾



目录
相关文章
|
定位技术 开发者
uni-app获取地理位置
uni-app获取地理位置
887 0
|
中间件 关系型数据库 Java
MySQL数据库分库分表方案
MySQL数据库分库分表方案
605 0
MySQL数据库分库分表方案
|
4月前
|
SQL Oracle 关系型数据库
MySQL的sql_mode模式说明及设置
MySQL的sql_mode模式说明及设置
625 112
|
7月前
|
传感器 物联网 Linux
Python:蓝牙心率广播设备监测(BLE 心率监测器)技术解析与实现
本文探讨了如何使用 Python 脚本与支持蓝牙低功耗(BLE)心率广播的设备交互以获取实时心率数据。重点分析了 BLE 协议、GATT 服务模型,以及具体方法。此外,还讨论了华为手表等设备的兼容性问题。
1361 19
|
网络协议 Linux
Linux如何查询端口被占用?
在Linux环境中,查询端口占用可使用`netstat`、`lsof`和`ss`命令。`netstat -tulnp | grep 80`显示TCP/UDP监听端口,`lsof -i:80`列出使用80端口的进程,而`ss -tuln | grep 80`是`netstat`的现代替代选项。若需解决端口占用问题,先找出占用进程的ID,然后用`kill -9`命令终止它,或调整服务配置以避免冲突。
1171 2
|
Cloud Native 关系型数据库 分布式数据库
开发者如何使用云原生数据库PolarDB
【10月更文挑战第5天】开发者如何使用云原生数据库PolarDB
428 2
|
SQL 监控 关系型数据库
【PolarDB开源】PolarDB SQL优化实践:提升查询效率与资源利用
【5月更文挑战第24天】PolarDB是高性能的云原生数据库,强调SQL查询优化以提升性能。本文分享了其SQL优化策略,包括查询分析、索引优化、查询重写、批量操作和并行查询,以及性能监控与调优方法。通过这些措施,可以减少响应时间、提高并发处理能力和降低成本。文中还提供了相关示例代码,展示如何分析查询和创建索引,帮助用户实现更高效的数据库管理。
600 1
|
关系型数据库 MySQL PHP
技术笔记:Sphinx速成指南
技术笔记:Sphinx速成指南
254 0