Lucene.net搜索结果排序(单条件和多条件)

Lucene支持对搜索条件的排序,一个条件或者多个条件,以及是升序还是降序,部分代码如下:

         string  INDEX_STORE_PATH  =  Server.MapPath( " index " );   // INDEX_STORE_PATH 为索引存储目录
         string  keyword  =  TextBox2.Text;                      // 搜索内容

        Hits myhit 
=   null ;
         
        IndexSearcher mysea 
=   new  IndexSearcher(INDEX_STORE_PATH);
        QueryParser q 
=   new  QueryParser( " indexcontent " new  StandardAnalyzer());
        Query query 
=  q.Parse(keyword);

        Sort sort 
=   new  Sort();
        SortField f 
=   new  SortField( " createdate " , SortField.STRING,  true ); // 按照createdate字段排序,true表示降序
        sort.SetSort(f);

        
// 多个条件排序
        
// Sort sort = new Sort();
        
// SortField f1 = new SortField("createdate", SortField.DOC, true);
        
// SortField f2 = new SortField("bookname", SortFiedl.INT, false);
        
// sort.setSort(new SortField[] { f1, f2 });

        myhit  =  mysea.Search(query, sort);
        Response.Write(
" 关于: "   +  keyword  +   "   搜索到 "   +  myhit.Length()  +   " 个结果<br> " );


对于数据量大(索引文件大于50M)的索引,尽量不要用索引中的字段排序,要用索引ID排序(INDEXORDER);两者效率相差近10倍。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值