日韩久久久精品,亚洲精品久久久久久久久久久,亚洲欧美一区二区三区国产精品 ,一区二区福利

lucene多樣化搜索,結果排序。

系統 1845 0
一:多樣化的搜索

/** *** 一個關鍵字,對一個字段進行查詢 **** */
QueryParser qp = new QueryParser("content",analyzer);
query = qp.parse(keyword);
Hits hits = searcher.search(query);

/** *** 模糊查詢 **** */
Term term = new Term("content",keyword);
FuzzyQuery fq = new FuzzyQuery(term);
Hits hits = searcher.search(fq);

/** *** 一個關鍵字,在兩個字段中查詢 **** */
/*
* 1.BooleanClause.Occur[]的三種類型: MUST : + and MUST_NOT : - not SHOULD : or
* 2.下面查詢的意思是:content中必須包含該關鍵字,而title有沒有都無所謂
* 3.下面的這個查詢中,Occur[]的長度必須和Fields[]的長度一致。每個限制條件對應一個字段
*/
BooleanClause.Occur[] flags = new BooleanClause.Occur[]{BooleanClause.Occur.SHOULD,BooleanClause.Occur.MUST};
query=MultiFieldQueryParser.parse(keyword,new String[]{"title","content"},flags,analyzer);


/** *** 兩個(多個)關鍵字對兩個(多個)字段進行查詢,默認匹配規則 **** */
/*
* 1.關鍵字的個數必須和字段的個數相等
* 2.由于沒有指定匹配規定,默認為"SHOULD" 因此,下面查詢的意思是:"title"中含有keyword1 或 "content"含有keyword2.
* 在此例中,把keyword1和keyword2相同
*/
query=MultiFieldQueryParser.parse(new String[]{keyword,keyword},new
String[]{"title","content"},analyzer);


/** *** 兩個(多個)關鍵字對兩個(多個)字段進行查詢,手工指定匹配規則 **** */
/*
* 1.必須 關鍵字的個數 == 字段名的個數 == 匹配規則的個數
* 2.下面查詢的意思是:"title"必須不含有keyword1,并且"content"中必須含有keyword2
*/
BooleanClause.Occur[] flags = new
BooleanClause.Occur[]{BooleanClause.Occur.MUST_NOT,BooleanClause.Occur.MUST};
query=MultiFieldQueryParser.parse(new String[]{keyword,keyword},new
String[]{"title","content"},flags,analyzer);


/** *** 對日期型字段進行查詢 **** */

/** *** 對數字范圍進行查詢 **** */
/*
* 1.兩個條件必須是同一個字段
* 2.前面一個條件必須比后面一個條件小,否則找不到數據
* 3.new RangeQuery中的第三個參數,表示是否包含"=" true: >= 或 <= false: > 或 <
* 4.找出 55>=id>=53 or 60>=id>=57:
*/
Term lowerTerm1 = new Term("id","53");
Term upperTerm1 = new Term("id","55");
RangeQuery rq1 = new RangeQuery(lowerTerm1,upperTerm1,true);

Term lowerTerm2 = new Term("id","57");
Term upperTerm2 = new Term("id","60");
RangeQuery rq2 = new RangeQuery(lowerTerm2,upperTerm2,true);

BooleanQuery bq = new BooleanQuery();
bq.add(rq1,BooleanClause.Occur.SHOULD);
bq.add(rq2,BooleanClause.Occur.SHOULD);
Hits hits = searcher.search(bq);


二:結果排序

排序的關鍵點有兩個:

1:首先你要排序的字段必須是被index的,并且是untokenized的。

如:

doc.add( new Field( " click " ,dv.get( " click " ).toString(),Field.Store.NO,Field.Index.UN_TOKENIZED));

2:在檢索時候:

如:

/***** 排序 *****/
/*
* 1.被排序的字段必須被索引過(Indexecd),在索引時不能 用 Field.Index.TOKENIZED
* (用UN_TOKENIZED可以正常實現.用NO時查詢正常,但排序不能正常設置升降序)
* 2.SortField類型
* SCORE、DOC、AUTO、STRING、INT、FLOAT、CUSTOM此類型主要是根據字段的類型選擇
* 3.SortField的第三個參數代表是否是降序true:降序 false:升序
*/
Sort sort = new Sort(new SortField[]{new SortField("click", SortField.INT, true)});
Hits hits = searcher.search(querystring,sort);

/*
* 按日期排序
*/
Sort sort = new Sort(new SortField[]{new SortField("createTime", SortField.INT, false)});


/***** 過濾器 ******/
QueryParser qp1 = new QueryParser("content",analyzer);
Query fquery = qp1.parse("我");

BooleanQuery bqf = new BooleanQuery();
bqf.add(fquery,BooleanClause.Occur.SHOULD);

QueryFilter qf = new QueryFilter(bqf);

Hits hits = searcher.search(query);

lucene多樣化搜索,結果排序。


更多文章、技術交流、商務合作、聯系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯系: 360901061

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對您有幫助就好】

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長會非常 感謝您的哦!!!

發表我的評論
最新評論 總共0條評論
主站蜘蛛池模板: 六枝特区| 乌审旗| 云龙县| 久治县| 东方市| 毕节市| 邢台县| 长沙县| 永寿县| 昆山市| 澄江县| 南阳市| 廉江市| 蓬安县| 永城市| 珲春市| 厦门市| 奇台县| 本溪市| 登封市| 固镇县| 周口市| 博野县| 大竹县| 上杭县| 甘孜| 手游| 江城| 台东市| 天等县| 英吉沙县| 且末县| 富锦市| 鸡东县| 万宁市| 涟源市| 舞钢市| 内丘县| 凯里市| 乌拉特后旗| 东兴市|