表格存儲-多元索引的limit限制提高到1000

本文介紹表格存儲(Tablestore)多元索引Search接口查詢數據的limit提高到1000的方法。

爲了提高使用多元索引Search接口單次查詢的返回結果數,當查詢數據時只查詢多元索引中的數據沒有反查數據表時,則limit限制自適應提高到1000,如果查詢數據時需要反查數據表,則limit限制爲100。

limit限制提高到1000的前提是沒有反查主表,只返回在多元索引中的屬性列,具體要求如下:

  1. 創建多元索引時候,指定字段的附加存儲爲true

    • 如果通過新版控制檯創建索引,默認爲true,不需要用戶選擇
    • 如果通過舊版控制檯創建索引,將“附加存儲”選項打開
    • 如果通過SDK創建索引,將字段的“FieldSchema”參數中的“store”參數設置爲true
  2. 通過search接口查詢時候,通過設置SearchRequest的ColumnsToGet參數,參數中僅返回設置過附加存儲的字段,且ColumnsToGet中不能有“數組類型”、“geo地理位置類型”、“nested嵌套類型”三種類型的字段。

注意:如果包含上述三種類型的字段,還是會觸發反查主表,則limit限制爲100;如果ColumnsToGet中設置的是常規的字段,則limit限制自適應提高到1000。後續我們會陸續放開數組字段、geo地理位置字段、nested嵌套字段可以返回。

Java代碼示例

此處以Java SDK爲例介紹如何設置ColumnsToGet參數,其他語言的SDK實現類似,只需修改SearchRequest中的ColumnsToGet參數即可。

SearchQuery searchQuery = new SearchQuery();
searchQuery.setQuery(new MatchQuery());
searchQuery.setLimit(1000);

SearchRequest searchRequest = new SearchRequest(tableName, indexName, searchQuery);
ColumnsToGet columnsToGet = new ColumnsToGet();
columnsToGet.setReturnAll(false);
columnsToGet.setColumns(Arrays.asList("field_1", "field_2", "field_3"));   // 列全字段名字,字段類型爲數組、nested嵌套字段、geo地理位置字段不能在裏面,不然會反查主表
searchRequest.setColumnsToGet(columnsToGet);
SearchResponse response = client.search(searchRequest);

// java-sdk-5.6.1及以後版本 ColumnsToGet參數支持returnAllColumnsFromIndex參數,獲取索引上的所有屬性列

ColumnsToGet columnsToGet = new ColumnsToGet();
columnsToGet.setReturnAllFromIndex(true);
searchRequest.setColumnsToGet(columnsToGet);
SearchResponse response = client.search(searchRequest);
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章