微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

如何查询DynamoDB表以仅检索字符串集属性内具有特定值的项目?

如何解决如何查询DynamoDB表以仅检索字符串集属性内具有特定值的项目?

我表中的项目的属性类型为字符串集。我将坚持使用文档中的示例并将其称为“颜色”。顾名思义,集合包含代表每个项目颜色的各种字符串。这看起来像 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类型的顶级属性。不允许使用其他数据类型,包括文档和集。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。