WEBUS2.0 In Action - 搜索操作指南 - (1)
上一篇:WEBUS2.0 In Action - 索引操作指南(2) | 下一篇:WEBUS2.0 In Action - 搜索操作指南(2)
1. IQueriable中内置的搜索功能
在Webus.Index.IQueriable中内置了一些基本的搜索功能:
public interface IQueriable
{
Document SelectDoc(); //获取第一个Document对象, 作为样本
List<Document> SelectDoc(int[] docIds); //根据docId获取Document
List<IndexDocInfo> SelectIndex(string fieldname, string keyword, int length); //在指定字段中根据关键词搜索, 只返回指定长度的数据
List<string> SelectPostfixKeyword(string postfix); //搜索满足后缀条件的关键词
List<string> SelectPrefixKeyword(string prefix); //搜索满足前缀条件的关键词
List<string> SelectRegexKeyword(string pattern, RegexOptions options); //搜索满足正则表达式的关键词
List<string> SelectWildcardKeyword(string wildcard); //搜索满足通配符的关键词
List<SequenceDocInfo> SelectSequence(string fieldname, object min, object max, bool asc, int length); //在指定字段中做范围搜索, 支持排序, 只返回指定长度的数据
List<SequenceDocInfo> SelectSequence(string fieldname, params int[] docIds); //在指定字段中根据docId来获取数据
List<string> GetKeywords(); //获取全部关键词
}
IQueryiable.SelectDoc() - 有时候用户需要知道索引中Document的结构, 从而可以对索引选项进行调整. 本方法就能够将索引列表中的第一个Document对象返回给调用方.
IQueriable.SelectDoc(int[] docIds) - 根据传入的docId列表来检索对应的Document列表.
IQueriable.SelectIndex(string fieldname, string keyword, int length) - 在字段fieldname中搜索关键词keyword, 并且只返回前length个结果. 这是Indexer的核心方法之一, 它的作用是在索引中检索数据. 这里特别要注意的是length这个参数, 其默认值是int.MaxValue, 但是WEBUS2.0 SDK对性能进行了深度优化, 在检索的时候只会扫描必需的索引文件: 假设最终生成的索引文件有3个片段, 我们对keyword进行搜索, 指定length=10. 在第一个片段index1中找到了6条结果, 在第二个片段index2中又找到了4条结果, 那么程序将跳过第三个片段index3直接返回, 从而节约系统开销. 因此在实际使用时合理的设置length, 是能够明显提升性能的.
IQueriable.SelectSequence(string fieldname, object min, object max, bool asc, int length) - 在WEBUS2.0中, 如果一个字段的属性被设置为FieldAttribute.Sort, 则意味着在编制索引的时候会为其生成序列 (Sequence). 比如Document结构如下:
Name : string : FieldAttribute.AnalyseIndex
Age : double : FieldAttribute.Sort
那么所有的Age字段将会被插入到一个排序表中, 也就是所谓序列. 通过SelectSequence方法, 我们就可以对这个序列进行检索, 从而实现范围查询.
p.s. 个人窃以为这是WEBUS2.0 SDK优于Lucene的一个功能点, 在Lucene中, 如果要实现同样的范围查询, 只能够用多次全文搜索来模拟, 比如查询 10 <= Age < 20的结果, 就需要模拟10个对Age的搜索, 分别是Age=10, Age=11, ... Age=19. 而如果Age=15.5, 虽然是落在这个范围内, 但是用这种模拟的方式是无论如何也检索不到的. 因此孰优孰劣, 一比便知.
IQueriable.SelectPost/Pre/Regex/WildcardKeyword(...) - 这4个方法是WEBUS2.0中的另一个亮点, 也是非常有意思的检索方法. WEBUS2.0在编制索引的时候, 同时对关键词本身也编制了索引. 这种增强的索引策略可以为我们带来多种多样的检索乐趣. 比如在前面代码搜索器的例子中, 我们要搜索以"Client"结尾的结果集. 这个时候就是利用上PostfixKeyword的功能来实现的: 首先搜索所有以"Client"结尾的关键词列表, 然后对每个关键词分别进行搜索, 最后将结果合并起来返回到调用端.
利用这些基本方法, 就能够满足简单的搜索要求. 但是对于大部分应用, 我们一定会有更加复杂的应用需求, 这个时候就需要用到Webus.Search.Query和Webus.Search.ISearcher. 它们的功能非常强大, 能够满足各种全文搜索需求. 我将在后文中详细介绍.
相关信息及WEBUS2.0 SDK下载:继续我的代码,分享我的快乐 - WEBUS2.0
WEBUS2.0 In Action - 搜索操作指南 - (1)的更多相关文章
- WEBUS2.0 In Action - 搜索操作指南 - (2)
上一篇:WEBUS2.0 In Action - 搜索操作指南(1) | 下一篇:WEBUS2.0 In Action - 搜索操作指南(3) 2. 使用Query Query是所有查询的基类, 它一 ...
- WEBUS2.0 In Action - 搜索操作指南 - (3)
上一篇:WEBUS2.0 In Action - 搜索操作指南(2) | 下一篇:WEBUS2.0 In Action - 搜索操作指南(4) 3. 评分机制 (Webus.Search.IHitSc ...
- WEBUS2.0 In Action - 搜索操作指南 - (4)
上一篇:WEBUS2.0 In Action - 搜索操作指南(3) 6. 搜索多个索引 为了提升性能, 我们可以从多个索引同时进行搜索, Webus.Search.MultiSearcher提供了相 ...
- WEBUS2.0 In Action - 索引操作指南(2)
上一篇:WEBUS2.0 In Action - 索引操作指南(1) | 下一篇:WEBUS2.0 In Action - 搜索操作指南(1) 3. 添加.删除.撤销删除和修改文档 在WEBUS中要将 ...
- WEBUS2.0 In Action - [源代码] - C#代码搜索器
最近由于工作的需要, 要分析大量C#代码, 在数万个cs文件中搜索特定关键词. 这是一项非常耗时的工作, 用Notepad++要运行接近半个小时. 于是我利用WEBUS2.0 SDK创建了一个代码搜索 ...
- 第二篇——Struts2的Action搜索顺序
Struts2的Action的搜索顺序: 地址:http://localhost:8080/path1/path2/student.action 1.判断package是否存在,例如:/pat ...
- Struts2学习三----------Action搜索顺序
© 版权声明:本文为博主原创文章,转载请注明出处 Struts2的Action的搜索顺序 http://localhost:8080/path1/path2/student.action 1)判断pa ...
- Struts2.0 去掉action后缀名
刚刚接触Struts2.0,发现默认请求都会带着后缀名:action 就如下图,url地址中会暴露login.action(请原谅struts拼写错误..) 作为一个URL简洁爱(chu)好(nv)者 ...
- 帝国cms7.0修改默认搜索模版中的分页[!--show.page--]
修改默认搜索模版的分页是在e/class/connect.php下 搜索下function page1就是我们要修改的分页了 下面贴上我修改后的分页 //前台分页 function page1($nu ...
随机推荐
- Mobile Web 调试指南(2):远程调试
原文:http://blog.jobbole.com/68606/ 原文出处: 阿伦孟的博客(@allenm ) 第一篇中讲解了如何让手机来请求我们开发电脑上的源码,做到了这步后,我们可以改完代码立即 ...
- list<T> 自定义比较器进行排序
今天在研究List<T> 集合如何排序,我试过很多,但是都不行,然后看到msdn中的这个比较器排序,自己测试了代码,No Problem.给大家分享一下. 类型 T 的默认比较器按如下方式 ...
- iOS第三方语音-讯飞语音
官方网站:http://www.xfyun.cn/ 注册还要绑定微信,坑啊,识别率感觉没得微信语音好,但是微信语音审核一直不过,研究下这个 1.下载sdk,主要就下面几个文件,我主要用的是语音识别
- SQL Server 中的存储过程
一:初步了解存储过程的使用 创建一个简单的存储过程 CREATE PROC spEmployee AS SELECT * FROM HumanResources.Employee; 执行这个存储过程: ...
- 解决安装rpm时lib冲突:libstdc++-2-libc6.1-1-2.9.0.so from install of compat-libstdc++-7.3-2.96.118 conflicts with file from ...
sudo rpm -ivh xxx.rpm -aid --force [oracle@localhost Oracle]$ .i386.rpm compat-libstdc++-devel-.i386 ...
- 将web项目deploy到tomcat的方法
如果已经把整个项目发布到tomcat的webapps文件夹下,就不用再配置tomcat的server.xml了(也就是不用配置<Context>节点) 并且,你的项目的WEB-INF/li ...
- java Comparable和Comaprator的对比
Comparable使一个class具备不同实例间进行比较的行为.这些对象的集合,可作为Collections.sort或Arrays.sort的参数 Comparator可以看成一种算法的实现,将算 ...
- org.opencv.android.JavaCameraView 摄像机方向的问题
——> org.opencv.android.JavaCameraView 摄像机方向的问题 ref: http://www.tuicool.com/articles/q6vUvqB 注意:一般 ...
- ACM数据结构相关资料整理【未完成,待补充】
在网上总是查不到很系统的练ACM需要学习的数据结构资料,于是参考看过的东西,自己整理了一份. 能力有限,欢迎大家指正补充. 分类主要参考<算法竞赛入门经典训练指南>(刘汝佳),山东大学数据 ...
- log log4net用代码记录日志
log4net 用代码记录日志 今天在开发项目的时候,遇到跨域调用log4net中的类,出现了一个bug,提示LogImpl未标记可序列化,此时,我靠,麻烦了,这个类又不是咱们自己的,改源码我想应该 ...