Lucene .Net 3.0.3查询语法

在使用查询语法前,必须确保筛选字段对应的Field属性的设置必须正确才可以用作查询条件
(Index:不为NO即可)
(如果需要查询的字段存储进去了,但是在取值的时候取不到值,只需要将对应Field的Store属性设置为YES即可)
(数字字段如果需要查询的话必须使用NumericField类型进行存储)

查询(多字段查询):
Lucene中如果需要用到查询语法则必须用到Query对象
Query是一个抽象类,他有很多的子类,所有的筛选都可以认为是创建了多个Query对象,然后将这多个对象进行组装

Lucene中的逻辑运算只有3个
Occur.MUST = 0, //AND
Occur.SHOULD = 1, //OR
Occur.MUST_NOT = 2 //NOT
通过将Query与逻辑运算符产生不同的组合,则可以拼出不同的筛选条件

BooleanQuery query1=new BooleanQuery();
//例如你的查询条件为 WHERE Name LIKE '%公司%' AND CompanyType=2;
//(名字中包含公司,并且公司类型是2的所有结果)
//如果是模糊查询则必须要使用"WildcardQuery"
query1.Add(new WildcardQuery(new Term("Name", "*公司*"),BooleanClause.Occur.MUST);
query1.Add(new TermQuery(new Term("CompanyType",2),BooleanClause.Occur.MUST);

BooleanQuery query2=new BooleanQuery();
//查询条件为 WHERE Name LIKE '%公司%' AND (CompanyType=2 OR CompanyType=3);
//(名字中包含公司,并且公司类型是2或者3的所有结果)
query2.Add(new WildcardQuery(new Term("Name", "*公司*"),BooleanClause.Occur.MUST);
var item_query= new BooleanQuery();
query_branch.Add(new TermQuery(new Term("CompanyType", 2)), Occur.SHOULD);
query_branch.Add(new TermQuery(new Term("CompanyType", 3)), Occur.SHOULD);
query2.Add(item_query, Occur.MUST);
//如果需要查询的字段是需要分词的(Document对应的字段也应该是Index.ANALYZED)
//SearchText:分词的字段
//LuceneWriter.analyzer:分词器,我用的分词器是JieBaAnalyzer 并且将他存在了内存中
var parser = new MultiFieldQueryParser(Lucene.Net.Util.Version.LUCENE_30, new string[] { "SearchText" }, LuceneWriter.analyzer);
query.Add( parser.Parse("输入的字符串"), Occur.MUST);
//如果查询条件中包含了范围,比如>XXX之类的
//这个表名了查询的ID必须在{1, int.MaxValue]之间,后2个布尔值表示包含或者不包含
query.Add(NumericRangeQuery.NewIntRange("ID", 1, int.MaxValue, false, true), Occur.MUST);
//最后的查询语法
//query:最终组织好的Query
//null:Filter,用法与Query差不多,但是Query会计算文档的评分,Filter则不会
//10:返回前10条文档
//Sort:new Sort(new SortField("OrderbyId", SortField.INT, true)) 排序语法
var hits=IndexSearcher.Search(query,null,10,new Sort(new SortField("OrderbyId", SortField.INT, true)));
//读取文档
foreach (var temp in hits.ScoreDocs)
{
     var doc =  IndexReader.Document(temp.Doc); //即可取到对应的文档,然后对这个文档进行操作即可完成读取操作
}
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Lucene.net 是一个开源的全文检索引擎库,它提供了一些基本的 API 来创建和维护索引,并且可以通过这些 API 来搜索索引中的文档。下面是一些使用 Lucene.net 的基本步骤: 1. 创建索引:使用 Lucene.net 的 API,可以创建一个空的索引。可以将文档添加到索引中,以便后续搜索。 2. 添加文档:使用 Lucene.net 的 API,可以将文档添加到索引中。可以为每个文档定义一个或多个字段。 3. 搜索索引:使用 Lucene.net 的 API,可以搜索索引中的文档。可以使用查询对象来指定搜索条件,例如搜索某个字段中包含特定关键字的文档。 4. 处理搜索结果:搜索结果是一组匹配查询条件的文档。可以使用 Lucene.net 的 API 来访问每个文档的字段,以便将搜索结果呈现给用户。 以下是一个简单的示例代码,可用于创建索引、添加文档和搜索索引: ``` // 创建索引 var indexDirectory = FSDirectory.Open(@"C:\myindex"); var analyzer = new StandardAnalyzer(LuceneVersion.LUCENE_48); var indexConfig = new IndexWriterConfig(LuceneVersion.LUCENE_48, analyzer); var writer = new IndexWriter(indexDirectory, indexConfig); // 添加文档 var doc = new Document(); doc.Add(new TextField("title", "Lucene.net tutorial", Field.Store.YES)); doc.Add(new TextField("content", "This is a tutorial on how to use Lucene.net for full text search.", Field.Store.YES)); writer.AddDocument(doc); // 搜索索引 var searcher = new IndexSearcher(writer.GetReader(true)); var queryParser = new QueryParser(LuceneVersion.LUCENE_48, "content", analyzer); var query = queryParser.Parse("full text search"); var topDocs = searcher.Search(query, 10); foreach (var scoreDoc in topDocs.ScoreDocs) { var doc = searcher.Doc(scoreDoc.Doc); Console.WriteLine(doc.Get("title")); } ``` 此示例创建一个名为“myindex”的索引目录,添加一个文档,然后搜索包含“full text search”关键字的文档。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值