问题描述
我表中的项目的属性类型为字符串集。我将坚持使用文档中的示例并将其称为“颜色”。顾名思义,集合包含代表每个项目颜色的各种字符串。这看起来像 this。
现在,我想查询表格,以便检索集合中具有特定颜色的所有项目。因此,对于所附图片,我想查询颜色“绿色”,并希望接收图片Picture2和Picture3。
有没有办法做到这一点?
由于所有可能的颜色和项目的数量巨大,加上仅很少数量的颜色与项目相关联,因此scan
的效率非常低。到目前为止,我尝试创建一个全局二级索引(GSI),但似乎无法按照我想要的方式进行,还是我做错了?
解决方法
除非您要搜索的字段内置在主键或辅助索引中,否则scan
将是您唯一的选择。
通过scan
操作,您可以使用contains
关键字搜索集合
let params = {
TableName : 'TABLE_NAME',FilterExpression: "contains(#color,:color)",ExpressionAttributeNames: {
"#color": "color",},ExpressionAttributeValues: {
":color": "Blue",}
};
documentClient.scan(params,function(err,data) {
console.log(data);
});
根据docs on secondary indexes,您不能使用集合作为主键来构建索引
索引的关键架构。索引键架构中的每个属性都必须是String,Number或Binary类型的顶级属性。不允许使用其他数据类型,包括文档和集。