BoolQuery查詢條件包含一個或者多個子查詢條件,根據子查詢條件來判斷一行數據是否滿足查詢條件。每個子查詢條件可以是任意一種Query類型,包括BoolQuery。
前提條件
已初始化OTSClient。具體操作,請參見初始化OTSClient。
已在數據表上創建多元索引。具體操作,請參見創建多元索引。
參數
參數 | 說明 |
mustQueries | 多個Query列表,行數據必須滿足所有的子查詢條件才算匹配,等價于And操作符。 |
mustNotQueries | 多個Query列表,行數據必須不能滿足任何的子查詢條件才算匹配,等價于Not操作符。 |
filterQueries | 多個Query列表,行數據必須滿足所有的子filter才算匹配,filter類似于query,區別是filter不會根據滿足的filterQueries個數進行相關性算分。 |
shouldQueries | 多個Query列表,可以滿足,也可以不滿足,等價于Or操作符。 一行數據應該至少滿足shouldQueries子查詢條件的最小匹配個數才算匹配。 如果滿足的shouldQueries子查詢條件個數越多,則整體的相關性分數更高。 |
minimumShouldMatch | shouldQueries子查詢條件的最小匹配個數。當同級沒有其他Query,只有shouldQueries時,默認值為1;當同級已有其他Query,例如mustQueries、mustNotQueries和filterQueries時,默認值為0。 |
getTotalCount | 是否返回匹配的總行數,默認為false,表示不返回。 返回匹配的總行數會影響查詢性能。 |
tableName | 數據表名稱。 |
indexName | 多元索引名稱。 |
columnsToGet | 是否返回所有列,包含returnAll和columns設置。 returnAll默認為false,表示不返回所有列,此時可以通過columns指定返回的列;如果未通過columns指定返回的列,則只返回主鍵列。 當設置returnAll為true時,表示返回所有列。 |
示例
使用多條件組合查詢的示例如下:
And條件查詢
進行And條件查詢時,您可以根據需要選擇是否使用相關性算分。
進行And條件查詢時使用相關性算分
以下示例用于通過BoolQuery進行And條件查詢,并對查詢結果使用相關性算分。
/**
* 通過BoolQuery進行And條件查詢。
* @param client
*/
public static void andQuery(SyncClient client){
/**
* 查詢條件一:RangeQuery,Col_Long的列值大于3。
*/
RangeQuery rangeQuery = new RangeQuery();
rangeQuery.setFieldName("Col_Long");
rangeQuery.greaterThan(ColumnValue.fromLong(3));
/**
* 查詢條件二:MatchQuery,Col_Keyword的列值要匹配"hangzhou"。
*/
MatchQuery matchQuery = new MatchQuery();
matchQuery.setFieldName("Col_Keyword");
matchQuery.setText("hangzhou");
SearchQuery searchQuery = new SearchQuery();
{
/**
* 構造一個BoolQuery,設置查詢條件為必須同時滿足"查詢條件一"和"查詢條件二"。
*/
BoolQuery boolQuery = new BoolQuery();
boolQuery.setMustQueries(Arrays.asList(rangeQuery, matchQuery));
searchQuery.setQuery(boolQuery);
//searchQuery.setGetTotalCount(true);//設置返回匹配的總行數。
SearchRequest searchRequest = new SearchRequest("<TABLE_NAME>", "<SEARCH_INDEX_NAME>", searchQuery);
//通過設置columnsToGet參數可以指定返回的列或返回所有列,如果不設置此參數,則默認只返回主鍵列。
//SearchRequest.ColumnsToGet columnsToGet = new SearchRequest.ColumnsToGet();
//columnsToGet.setReturnAll(true); //設置為返回所有列。
//columnsToGet.setColumns(Arrays.asList("ColName1","ColName2")); //設置為返回指定列。
//searchRequest.setColumnsToGet(columnsToGet);
SearchResponse resp = client.search(searchRequest);
//System.out.println("TotalCount: " + resp.getTotalCount()); //打印匹配到的總行數,非返回行數。
System.out.println("Row: " + resp.getRows());
}
}
進行And條件查詢時忽略相關性算分
以下示例用于通過BoolQuery進行And條件查詢,對查詢結果忽略相關性算分。
/**
* 通過BoolQuery進行And條件查詢,忽略相關性算分
* @param client
*/
public static void filtersQuery(SyncClient client){
/**
* 查詢條件一:RangeQuery,Col_Long的列值大于3。
*/
RangeQuery rangeQuery = new RangeQuery();
rangeQuery.setFieldName("Col_Long");
rangeQuery.greaterThan(ColumnValue.fromLong(3));
/**
* 查詢條件二:MatchQuery,Col_Keyword的列值要匹配"hangzhou"。
*/
MatchQuery matchQuery = new MatchQuery();
matchQuery.setFieldName("Col_Keyword");
matchQuery.setText("hangzhou");
SearchQuery searchQuery = new SearchQuery();
{
/**
* 構造一個BoolQuery,設置查詢條件為必須同時滿足"查詢條件一"和"查詢條件二"。
*/
BoolQuery boolQuery = new BoolQuery();
boolQuery.setFilterQueries(Arrays.asList(rangeQuery, matchQuery));
searchQuery.setQuery(boolQuery);
//searchQuery.setGetTotalCount(true);//設置返回匹配的總行數。
SearchRequest searchRequest = new SearchRequest("sampleTable", "sampleSearchIndex", searchQuery);
//通過設置columnsToGet參數可以指定返回的列或返回所有列,如果不設置此參數,則默認只返回主鍵列。
//SearchRequest.ColumnsToGet columnsToGet = new SearchRequest.ColumnsToGet();
//columnsToGet.setReturnAll(true); //設置為返回所有列。
//columnsToGet.setColumns(Arrays.asList("ColName1","ColName2")); //設置為返回指定列。
//searchRequest.setColumnsToGet(columnsToGet);
SearchResponse resp = client.search(searchRequest);
//System.out.println("TotalCount: " + resp.getTotalCount()); //打印匹配到的總行數,非返回行數。
System.out.println("Row: " + resp.getRows());
}
}
Or條件查詢
以下示例用于通過BoolQuery進行Or條件查詢。
/**
* 通過BoolQuery進行Or條件查詢。
* @param client
*/
public static void orQuery(SyncClient client) {
/**
* 查詢條件一:RangeQuery,Col_Long的列值大于3。
*/
RangeQuery rangeQuery = new RangeQuery();
rangeQuery.setFieldName("Col_Long");
rangeQuery.greaterThan(ColumnValue.fromLong(3));
/**
* 查詢條件二:MatchQuery,Col_Keyword的列值要匹配"hangzhou"。
*/
MatchQuery matchQuery = new MatchQuery();
matchQuery.setFieldName("Col_Keyword");
matchQuery.setText("hangzhou");
SearchQuery searchQuery = new SearchQuery();
{
/**
* 構造一個BoolQuery,設置查詢條件為至少滿足"條件一"和"條件二"中的一個條件。
*/
BoolQuery boolQuery = new BoolQuery();
boolQuery.setShouldQueries(Arrays.asList(rangeQuery, matchQuery));
boolQuery.setMinimumShouldMatch(1); //設置至少滿足一個條件。
searchQuery.setQuery(boolQuery);
//searchQuery.setGetTotalCount(true);//設置返回匹配的總行數。
SearchRequest searchRequest = new SearchRequest("<TABLE_NAME>", "<SEARCH_INDEX_NAME>", searchQuery);
//通過設置columnsToGet參數可以指定返回的列或返回所有列,如果不設置此參數,則默認只返回主鍵列。
//SearchRequest.ColumnsToGet columnsToGet = new SearchRequest.ColumnsToGet();
//columnsToGet.setReturnAll(true); //設置為返回所有列。
//columnsToGet.setColumns(Arrays.asList("ColName1","ColName2")); //設置為返回指定列。
//searchRequest.setColumnsToGet(columnsToGet);
SearchResponse resp = client.search(searchRequest);
//System.out.println("TotalCount: " + resp.getTotalCount()); //打印匹配到的總行數,非返回行數
System.out.println("Row: " + resp.getRows());
}
}
Not條件查詢
以下示例用于通過BoolQuery進行Not條件查詢。
/**
* 通過BoolQuery進行Not條件查詢。
* @param client
*/
public static void notQuery(SyncClient client) {
/**
* 查詢條件一:MatchQuery,Col_Keyword的列值要匹配"hangzhou"。
*/
MatchQuery matchQuery = new MatchQuery();
matchQuery.setFieldName("Col_Keyword");
matchQuery.setText("hangzhou");
SearchQuery searchQuery = new SearchQuery();
{
/**
* 構造一個BoolQuery,設置查詢條件為不滿足"查詢條件一"。
*/
BoolQuery boolQuery = new BoolQuery();
boolQuery.setMustNotQueries(Arrays.asList(matchQuery));
searchQuery.setQuery(boolQuery);
//searchQuery.setGetTotalCount(true);//設置返回匹配的總行數。
SearchRequest searchRequest = new SearchRequest("<TABLE_NAME>", "<SEARCH_INDEX_NAME>", searchQuery);
//通過設置columnsToGet參數可以指定返回的列或返回所有列,如果不設置此參數,則默認只返回主鍵列。
//SearchRequest.ColumnsToGet columnsToGet = new SearchRequest.ColumnsToGet();
//columnsToGet.setReturnAll(true); //設置為返回所有列。
//columnsToGet.setColumns(Arrays.asList("ColName1","ColName2")); //設置為返回指定列。
//searchRequest.setColumnsToGet(columnsToGet);
SearchResponse resp = client.search(searchRequest);
//System.out.println("TotalCount: " + resp.getTotalCount()); //打印匹配到的總行數,非返回行數。
System.out.println("Row: " + resp.getRows());
}
}
組合查詢
以下示例用于含有子BoolQuery的組合查詢。使用多條件組合查詢實現(col2<4 or col3<5) or (col2 = 4 and (col3 = 5 or col3 =6)),每個and或or相當于一個BoolQuery,多個表達式的and或or就是多個BoolQuery的組合。
/**
* (col2<4 or col3<5) or (col2 = 4 and (col3 = 5 or col3 =6))
* 使用多條件組合查詢上述表達式,每個and或or相當于一個BoolQuery,多個表達式的and或or就是多個BoolQuery的組合。
* @param client
*/
private static void boolQuery2(SyncClient client){
//條件1為col2<4。
RangeQuery rangeQuery1 = new RangeQuery();
rangeQuery1.setFieldName("col2");
rangeQuery1.lessThan(ColumnValue.fromLong(4));
//條件2為col3<5。
RangeQuery rangeQuery2 = new RangeQuery();
rangeQuery2.setFieldName("col3");
rangeQuery2.lessThan(ColumnValue.fromLong(5));
//條件3為col2=4。
TermQuery termQuery = new TermQuery();
termQuery.setFieldName("col2");
termQuery.setTerm(ColumnValue.fromLong(4));
//條件4為col3 = 5 or col3 = 6。
TermsQuery termsQuery = new TermsQuery();
termsQuery.setFieldName("col3");
termsQuery.addTerm(ColumnValue.fromLong(5));
termsQuery.addTerm(ColumnValue.fromLong(6));
SearchQuery searchQuery = new SearchQuery();
List<Query> queryList1 = new ArrayList<>();
queryList1.add(rangeQuery1);
queryList1.add(rangeQuery2);
//組合條件1為col2<4 OR col3<5。
BoolQuery boolQuery1 = new BoolQuery();
boolQuery1.setShouldQueries(queryList1);
//組合條件2為col2=4 and (col3=5 or col3=6)。
List<Query> queryList2 = new ArrayList<>();
queryList2.add(termQuery);
queryList2.add(termsQuery);
BoolQuery boolQuery2 = new BoolQuery();
boolQuery2.setMustQueries(queryList2);
//總組合條件為(col2<4 OR col3<5) or (col2=4 and (col3=5 or col3=6))。
List<Query> queryList3 = new ArrayList<>();
queryList3.add(boolQuery1);
queryList3.add(boolQuery2);
BoolQuery boolQuery = new BoolQuery();
boolQuery.setShouldQueries(queryList3);
searchQuery.setQuery(boolQuery);
//searchQuery.setGetTotalCount(true);//設置返回匹配的總行數。
SearchRequest searchRequest = new SearchRequest("<TABLE_NAME>", "<SEARCH_INDEX_NAME>", searchQuery);
//通過設置columnsToGet參數可以指定返回的列或返回所有列,如果不設置此參數,則默認只返回主鍵列。
//SearchRequest.ColumnsToGet columnsToGet = new SearchRequest.ColumnsToGet();
//columnsToGet.setReturnAll(true); //設置為返回所有列。
//columnsToGet.setColumns(Arrays.asList("ColName1","ColName2")); //設置為返回指定列。
//searchRequest.setColumnsToGet(columnsToGet);
SearchResponse response = client.search(searchRequest);
//System.out.println("TotalCount: " + resp.getTotalCount()); //打印匹配到的總行數,非返回行數。
System.out.println(response.getRows());
}
常見問題
相關文檔
多元索引查詢類型包括精確查詢、多詞精確查詢、全匹配查詢、匹配查詢、短語匹配查詢、前綴查詢、范圍查詢、通配符查詢、地理位置查詢、向量檢索、多條件組合查詢、嵌套類型查詢和列存在性查詢,您可以選擇合適的查詢類型進行多維度數據查詢。
如果要對結果集進行排序或者翻頁,您可以使用排序和翻頁功能來實現。具體操作,請參見排序和翻頁。
如果要按照某一列對結果集做折疊,使對應類型的數據在結果展示中只出現一次,您可以使用折疊(去重)功能來實現。具體操作,請參見折疊(去重)。
如果要進行數據分析,例如求最值、求和、統計行數等,您可以使用Search接口的統計聚合功能或者SQL查詢來實現。具體操作,請參見統計聚合和SQL查詢。
如果要快速導出數據,而不關心整個結果集的順序時,您可以使用ParallelScan接口和ComputeSplits接口實現多并發導出數據。具體操作,請參見并發導出數據。