coreseek/sphinx中的匹配模式
所谓匹配模式就是用户怎样依据keyword在索引库中查找相关的记录。
SPH_MATCH_ALL, 匹配全部查询分词(默认模式);
如“手机配件”。不匹配 “我有一部手机”,但能够匹配 “手机坏了,须要找配件”。
由于“手机配件” 被分成 “手机”,“配件”两个词。匹配条件是必须同一时候包括这两个词。所以“我有一部手机”不符合匹配要求。
SPH_MATCH_ANY, 匹配查询词中的随意一个分词;
如“手机配件”。会匹配“我有一部手机”,由于索引库仅仅要包括任一个分词就可以被搜到,当然也能匹配“手机坏了,须要找配件”。
SPH_MATCH_PHRASE, 将整个查询看作一个词组。要求按顺序完整匹配;
这个与select * from [tab] where key like '%手机配件%'相相似,如“手机配件”,不匹配 “手机坏了,须要找配件”,但能够匹配 “你这儿有手机配件吗?
”。
SPH_MATCH_BOOLEAN, 将查询看作一个布尔表达式, 能够简单的与或非运算;
如( cat !dog ) | ( cat !mouse)
意思是搜索出全部匹配cat,但不匹配dog和mouse的查询分词。
SPH_MATCH_EXTENDED2,扩展匹配模式
将查询看作一个Sphinx/Coreseek内部查询语言的表达式。
在扩展查询模式中能够使用例如以下特殊操作符:
- 或(OR)操作符:
hello | world
- 非(NOT)操作符:
hello -world
hello !world
- 字段(field)搜索符:
@title hello @body world
#title 字段中包括hello body字段中包括world
- 字段限位修饰符
@body[50] hello
#body位数限制在50以内
- 多字段搜索符:
@(title,body) hello world
#title 或 body字段中包括Hello world
- 全字段搜索符:
@* hello
#仅仅要当中一列包括hello
- 近似搜索符:
"hello world"~10
#hello world之间最多有10个词
- 阀值匹配符:
"the world is a wonderful place"/3
#至少匹配3个词
- 严格有序搜索符(即“在前”搜索符):
aaa << bbb << ccc
#aaa,bbb,ccc必须按先后顺序出现
- 字段開始和字段结束修饰符
^hello ... world$
#限定必须以hello开头。以world结尾
如:"hello world" @title "example program"~10 @body python -(php|perl) @* code
要求同一时候匹配:
在文档的随意字段中找相邻的“hello”和“world”
文档的title字段中还必须包括 “example”和“program”这两个词,而且他们之间至多有10个(不包括10个)其它的词
同一时候。body字段必须含有词“python”。但既没有“php”也没有“perl”
任一字段中包括”code“
SPH_MATCH_EXTENDED, 同SPH_MATCH_EXTENDED2, 为了兼容旧版本号;
SPH_MATCH_FULLSCAN, 强制使用下文所述的“完整扫描”模式来对查询进行匹配;
注意,在此模式下。全部的查询词都被忽略。虽然过滤器、过滤器范围以及分组仍然起作用。但不论什么文本匹配都不会发生.
这里不做文本匹配,即使你传递查询词也将被忽略,一般作为过滤来用,比方说,我在餐厅索引中搜索北京的全部餐厅,我仅仅要将北京地名的id用SetFilter方法来过滤就可以。
PHP中通过setMatchMode函数来设置,如:
<?php
$sc = new SphinxClient();
$sc->setMatchMode(SPH_MATCH_ANY);
coreseek/sphinx中的匹配模式的更多相关文章
- fgrep---指定的输入文件中的匹配模式的行
fgrep命令是用来搜索 file 参数指定的输入文件(缺省为标准输入)中的匹配模式的行.fgrep 命令特别搜索 Pattern 参数,它们是固定的字符串.如果在 File 参数中指定一个以上的文件 ...
- scala 中的匹配模式
unapply 仅作匹配,不作其它输出.返回 Boolean 值 object UpperCase { def unapply(s: String): Boolean = s.toUpperCase ...
- Sphinx 匹配模式
所谓匹配模式就是用户如何根据关键字在索引库中查找相关的记录. SPH_MATCH_ALL, 匹配所有查询分词(默认模式); 如“手机配件”,不匹配 “我有一部手机”,但可以匹配 “手机坏了,需要找配件 ...
- SQL中常用模糊查询的四种匹配模式&&正则表达式
执行数据库查询时,有完整查询和模糊查询之分.一般模糊语句如下:SELECT 字段 FROM 表 WHERE 某字段 Like 条件 其中关于条件,SQL提供了四种匹配模式:1.%:表示任意0个或多个字 ...
- Javascript中正则表达式的全局匹配模式
先看一道JavaScript题目,据说是国内某知名互联网企业的JavaScript笔试题,如果对正则的全局匹配模式不了解的话可能会对下面的输出结果感到疑惑. var str = "123#a ...
- 搭建coreseek(sphinx+mmseg3)详细安装配置+php之sphinx扩展安装+php调用示例(转)
一个文档包含了安装.增量备份.扩展.api调用示例,省去了查找大量文章的时间. 搭建coreseek(sphinx+mmseg3)安装 [第一步] 先安装mmseg3 cd /var/install ...
- Coreseek/sphinx全文检索的了解
Coreseek/sphinx全文检索的了解 概述: 全文检索是一种将文件里全部文本与检索项匹配的文字资料检索方法,全文检索是将存储于数据库中整本书.整篇文章中的随意内容信息查找出来的检索.它能够依据 ...
- 制作类似ThinkPHP框架中的PATHINFO模式功能
一.PATHINFO功能简述 搞PHP的都知道ThinkPHP是一个免费开源的轻量级PHP框架,虽说轻量但它的功能却很强大.这也是我接触学习的第一个框架.TP框架中的URL默认模式即是PathInfo ...
- grep中正则匹配的使用
如要匹配Computer或computer两个单词,可做如下操作: [Cc]mputer “.”允许匹配ASCII集中任意字符,或为字母,或为数字. 使用\{\}匹配模式结果出现的次数 匹配字母A出现 ...
随机推荐
- Set 里的元素是不能重复的,那么用什么方法来区分重复与否呢?是用==还 是 equals()?它们有何区别?
Set 里的元素是不能重复的,元素重复与否是使用 equals()方法进行判断的.equals()和==方法决定引用值是否指向同一对象 equals()在类中被覆盖,为的是当两个分离的对象的内容和类型 ...
- Java NIO系列1-概观
Java NIO系列1-概观 Java NIO.中间的N你既可以理解为(new),也就是新的IO,相对于java1.5之前的IO它确实是新的;也可以理解为(no-blocking),也就是非阻塞的IO ...
- Codeforces 522D Closest Equals
题解: 傻逼题 直接从左向右扫描每个点作为右端点 然后单点修改区间查询就行了 另外一种更直观的做法就是$(i,j)$之间产生了$(j-i)$ 于是变成矩形查最大值,kd-tree维护 代码: #inc ...
- [转自大神]js拖拽小总结
https://blog.csdn.net/u013040887/article/details/83059094 权侵删 这里写的是一个原生js实现拖拽的效果,首先: 1.实现拖拽的三大事件,是要首 ...
- pandas 必背函数操作
1.五个常用属性 index,columns,shape,values,dtypes2.常用函数:set_index,reset_index,del df['column_name'],pd.read ...
- [R] R语言for循环机制
在做数据分段截取的时候,发现for循环的表现和其他语言不太一样. 上代码: :) { i = i + print(i) } 结果: [] [] [] [] 即作为循环计次的i, 并不会因为在循环体中的 ...
- Django——图书管理系统
基于Django的图书管理系统 1.主体功能 1.列出图书列表.出版社列表.作者列表 2.点击作者,会列出其出版的图书列表 3.点击出版社,会列出旗下图书列表 4.可以创建.修改.删除 图书.作者.出 ...
- Python学习笔记整理(python 3)
一.tuple(元组) tuple和list非常类似,但是tuple一旦初始化就不能修改,如: classmates = ('Michael', 'Bob', 'Tracy') 1 classmate ...
- Phone List 字典树 OR STL
Phone List Time Limit: 1 Sec Memory Limit: 128 Mb Submitted: 140 Solved: 35 Description ...
- 51nod 1617 奇偶数组
传送门 回来看一眼51nod,发现自己掉到rank4了,赶紧切道题回rank3. 一眼不会做,这种东西应该慢慢找规律吧……然后看到数据范围其实比较小,应该是单次log的,那是不是可以分治啊. #inc ...