//AND 並且
SolrQuery params = new SolrQuery("name:apple AND manu:inc");
//OR 或者
params.setQuery("name:apple OR manu:apache");
//空格 等同於 OR
params.setQuery("name:server manu:dell");
//params.setQuery("name:solr - manu:inc");
//params.setQuery("name:server + manu:dell");
//查詢name包含solr apple
params.setQuery("name:solr,apple");
//manu不包含inc
params.setQuery("name:solr,apple NOT manu:inc");
//50 <= price <= 200
params.setQuery("price:[50 TO 200]");
params.setQuery("popularity:[5 TO 6]");
//params.setQuery("price:[50 TO 200] - popularity:[5 TO 6]");
//params.setQuery("price:[50 TO 200] + popularity:[5 TO 6]");
//50 <= price <= 200 AND 5 <= popularity <= 6
params.setQuery("price:[50 TO 200] AND popularity:[5 TO 6]");
params.setQuery("price:[50 TO 200] OR popularity:[5 TO 6]");
//過濾器查詢,可以提高性能 filter 類似多個條件組合,如and
//params.addFilterQuery("id:VA902B");
//params.addFilterQuery("price:[50 TO 200]");
//params.addFilterQuery("popularity:[* TO 5]");
//params.addFilterQuery("weight:*");
//0 < popularity < 6 沒有等於
//params.addFilterQuery("popularity:{0 TO 6}");
//排序
params.addSortField("id", ORDER.asc);
//分頁:start開始頁,rows每頁顯示記錄條數
//params.add("start", "0");
//params.add("rows", "200");
//params.setStart(0);
//params.setRows(200);
//設置高亮
params.setHighlight(true); // 開啓高亮組件
params.addHighlightField("name");// 高亮字段
params.setHighlightSimplePre("<font color='red'>");//標記,高亮關鍵字前綴
params.setHighlightSimplePost("</font>");//後綴
params.setHighlightSnippets(1);//結果分片數,默認爲1
params.setHighlightFragsize(1000);//每個分片的最大長度,默認爲100
//分片信息
params.setFacet(true)
.setFacetMinCount(1)
.setFacetLimit(5)//段
.addFacetField("name")//分片字段
.addFacetField("inStock");
//params.setQueryType("");
try {
QueryResponse response = server.query(params);
/*List<Index> indexs = response.getBeans(Index.class);
for (int i = 0; i < indexs.size(); i++) {
fail(indexs.get(i));
}*/
//輸出查詢結果集
SolrDocumentList list = response.getResults();
fail("query result nums: " + list.getNumFound());
for (int i = 0; i < list.size(); i++) {
fail(list.get(i));
}
//輸出分片信息
List<FacetField> facets = response.getFacetFields();
for (FacetField facet : facets) {
fail(facet);
List<Count> facetCounts = facet.getValues();
for (FacetField.Count count : facetCounts) {
System.out.println(count.getName() + ": " + count.getCount());
}
}
} catch (SolrServerException e) {
e.printStackTrace();
}
solrJ查詢使用
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章
安裝配置apache-solr(使用apache-tomcat容器)
vfast_wuwei
2019-02-23 12:55:35
Docker使用supervisor構建solr
aarongo
2019-02-22 22:55:25
Solr Document [null] missing required field: id 的原因
llwbrothers
2019-02-22 22:46:15
SolrCloud6.1.0之SQL查詢測試
葬月仙帝
2019-02-22 22:07:09
如何使用Hive集成Solr?
葬月仙帝
2019-02-22 22:07:08
如何監控 Apache Solr ?
hyperichq
2019-02-22 21:46:35
solrCloud+tomcat+zookeeper配置
fayong_zhou
2019-02-22 20:18:39
zabbix 監控solr
liangey
2019-02-22 18:23:04
tomca+solr安裝
liangey
2019-02-22 18:23:01
solr的DIH操作同步mysql數據
yushiwh
2019-02-22 16:33:40
Docker使用supervisor構建solr
aarongo
2019-02-16 13:04:55
php操作solr7.5通過mysql導入的數據
霜見
2018-12-07 12:51:30
我的一個笨重的控制檯計算器高亮效果
zjj1211
2019-02-22 20:33:43