Lucene.net – Query
2009-07-22 22:31
357 查看
有人反应上一篇写的有点偏题,标题是lucene.net,内容却说的是lucene。我仔细想了想,确实有些不妥,虽然lucene和lucene.net的接口完全一样,内部原理也是一样,但是一个是Java平台,一个是.NET平台,还是要把概念分分清楚的。
今天先补充一个昨天没有提到的细节,就是怎样获得lucene.net并加入自己的项目。
lucene.net使用svn进行源代码管理,所以首先下载SVN客户端,我这里使用的是tortoisesvn。
![](http://images.cnblogs.com/cnblogs_com/scott-xu/WindowsLiveWriter/Lucene.netQuery_12EFC/image_5.png)
安装完tortoisesvn后,选择目标文件夹,右击选择svn check out,url:https://svn.apache.org/repos/asf/incubator/lucene.net/trunk/,这样就可以下载下来最新的lucene.net源代码了。
打开解决方案,编译,得到的dll文件就是我们需要的东东了。在需要他的项目里引用这个dll就ok了,当然你也可以引用这个项目。
![](http://images.cnblogs.com/cnblogs_com/scott-xu/WindowsLiveWriter/Lucene.netQuery_12EFC/image_6.png)
今天主要来说一说怎么利用lucene.net来查询。先来看代码:
code
首先还是建立一个标准分析器,然后建立一个索引查对象(昨天是索引写对象),在构造索引查对象的时候,传入索引位置,即上一篇创建的索引所在的文件夹。接着创建一个多字段的查询解析器,该对象指定了对哪些字段进行检索,当然前提是对这些字段做了索引。然后通过解析器对关键字进行解析,得到查询对象。最后索引查对象通过查询对象查找结果,结果就是hits了,表示击中了多少目标。
最后把查找的结果一一输出,不过为什么这里只输出id呢?请读者结合上一篇思考。
这就是一个很简单的利用lucene.net进行检索的一个例子。
明天会说到为什么只输出id,以及相关的一些内容。
今天先补充一个昨天没有提到的细节,就是怎样获得lucene.net并加入自己的项目。
lucene.net使用svn进行源代码管理,所以首先下载SVN客户端,我这里使用的是tortoisesvn。
![](http://images.cnblogs.com/cnblogs_com/scott-xu/WindowsLiveWriter/Lucene.netQuery_12EFC/image_5.png)
安装完tortoisesvn后,选择目标文件夹,右击选择svn check out,url:https://svn.apache.org/repos/asf/incubator/lucene.net/trunk/,这样就可以下载下来最新的lucene.net源代码了。
打开解决方案,编译,得到的dll文件就是我们需要的东东了。在需要他的项目里引用这个dll就ok了,当然你也可以引用这个项目。
![](http://images.cnblogs.com/cnblogs_com/scott-xu/WindowsLiveWriter/Lucene.netQuery_12EFC/image_6.png)
今天主要来说一说怎么利用lucene.net来查询。先来看代码:
code
static void Main(string[] args) { Analyzer analyzer = new StandardAnalyzer(); IndexSearcher searcher = new IndexSearcher("IndexDirectory"); MultiFieldQueryParser parser = new MultiFieldQueryParser(new string[] { "title", "content" }, analyzer); Query query = parser.Parse("sql"); Hits hits = searcher.Search(query); for (int i = 0; i < hits.Length(); i++) { Document doc = hits.Doc(i); Console.WriteLine(doc.Get("id")); } searcher.Close(); Console.ReadKey(); }
首先还是建立一个标准分析器,然后建立一个索引查对象(昨天是索引写对象),在构造索引查对象的时候,传入索引位置,即上一篇创建的索引所在的文件夹。接着创建一个多字段的查询解析器,该对象指定了对哪些字段进行检索,当然前提是对这些字段做了索引。然后通过解析器对关键字进行解析,得到查询对象。最后索引查对象通过查询对象查找结果,结果就是hits了,表示击中了多少目标。
最后把查找的结果一一输出,不过为什么这里只输出id呢?请读者结合上一篇思考。
这就是一个很简单的利用lucene.net进行检索的一个例子。
明天会说到为什么只输出id,以及相关的一些内容。
相关文章推荐
- Lucene.Net RangeQuery 效率确实低下
- lucene.net 的查询方式query,条件判断
- lucene.net 使用过程中的 几个注意事项(含termquery 和QueryParser 的区别)
- 利用 lucene.net 实现高效率的 WildcardQuery ,记一次类似百度搜索下拉关键字联想功能的实现。
- lucene.net 的查询方式query条件判断
- Lucene.Net学习 TermQuery,NumericRangeQuery,TermRangeQuery的使用(一)
- (转)lucene.net 的查询方式query,条件判断
- Lucene.Net3.0.3+盘古分词器学习使用
- NHibernate.Search 基于Lucene.NET的全文索引
- 重新一步一步学习Lucene.NET 一个简单的程序开始(1)
- ASP.NET 以 Request.Querystring、Request.Form 或 Request.Params 获取客户端的数据
- 小叮咚切分词方法加入sourceforge.net中WebLucene分词模块
- 代码阅读总结之ASP.NET StartKit TimeTracker(QueryString之改进笔记)
- lucene.net三种检索形式 备忘
- ASP.NET中Get和Post的用法 Request.QueryString,Request.Form,Request.Params的区别 [转]
- lucene.net 详解
- lucene.net 2.0分析-1-草稿
- lucene利用BooleanQuery进行多个Query组合查询
- HubbleDotNet 和 Lucene.Net 匹配相关度的比较
- lucene.net学习七——分词