您现在的位置是:首页 > 文章详情

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

日期:2020-06-01点击:577

本文介绍表格存储(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);
原文链接:https://yq.aliyun.com/articles/763431
关注公众号

低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。

持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。

转载内容版权归作者及来源网站所有,本站原创内容转载请注明来源。

文章评论

共有0条评论来说两句吧...

文章二维码

扫描即可查看该文章

点击排行

推荐阅读

最新文章