加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

c# – Lucene.NET并使用特定值搜索多个字段

发布时间:2020-12-15 08:06:34 所属栏目:百科 来源:网络整理
导读:我已经为我添加的每个文档创建了一个包含各种数据位的索引,每个文档的字段名称都不同. 稍后,当我来搜索索引时,我需要使用确切的字段/值来查询它 – 例如: FieldName1 = X AND FieldName2 = Y AND FieldName3 = Z 使用Lucene .NET构建以下内容的最佳方法是什
我已经为我添加的每个文档创建了一个包含各种数据位的索引,每个文档的字段名称都不同.

稍后,当我来搜索索引时,我需要使用确切的字段/值来查询它 – 例如:

FieldName1 = X AND FieldName2 = Y AND FieldName3 = Z

使用Lucene .NET构建以下内容的最佳方法是什么:

>对于这种完全匹配类型,最适合使用哪种分析仪?
>在检索匹配时,我只需要返回一个特定字段(我将其添加到每个文档中) – 这应该是唯一存储的字段吗?
>稍后我需要支持关键字搜索(因此字段可以包含值列表,我需要进行部分匹配).

字段和值来自Dictionary< string,string>.它不是用户输入,而是由代码构造的.

谢谢,
基隆

解决方法

好吧,我最终想出来了 – 这是我对它的看法(这可能是完全错误的,但它适用于):
public Guid? Find (Dictionary<string,string> searchTerms)
{
    if (searchTerms == null)
        throw new ArgumentNullException ("searchTerms");

    try
    {
            var directory = FSDirectory.Open (new DirectoryInfo (IndexRoot));
            if (!IndexReader.IndexExists (directory))
                return null;

            var mainQuery = new BooleanQuery ();
            foreach (var pair in searchTerms)
            {
                var parser = new QueryParser (
                    Lucene.Net.Util.Version.LUCENE_CURRENT,pair.Key,GetAnalyzer ());
                var query = parser.Parse (pair.Value);

                mainQuery.Add (query,BooleanClause.Occur.MUST);
            }

            var searcher = new IndexSearcher (directory,true);

            try
            {
                var results = searcher.Search (mainQuery,(Filter)null,10);
                if (results.totalHits != 1)
                    return null;

                return Guid.Parse (searcher.Doc (results.scoreDocs[0].doc).Get (ContentIdKey));
            }
            catch
            {
                throw;
            }
            finally
            {
                if (searcher != null)
                    searcher.Close ();
            }
    }
    catch
    {
            throw;
    }
}

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读