DynamoDB:scan()与FilterExpression结合使用多个属性

问题描述 投票:0回答:1

DynamoDB表中的项目具有以下格式:

{
  'id': 1,
  'last_check': 1234556,
  'check_interval': 100,
  ....
}

现在我想扫描表格,找到last_check + check_interval小于某个给定值last_check_time的所有项目。我没有找到一种方法来创建一个结合了两个属性的FilterExpression,所以我目前正在通过以下方式进行:

last_check_time = time.time()
response = status_table.scan(
    ProjectionExpression='id, last_check, check_interval',
    FilterExpression = Attr('last_check').lt(last_check_time)
)
# manually filter the items and only preserve those with last_check + check_interval < last_check_time:
for item in response['Items']:
    if item['last_check'] + item['check_interval'] < last_check_time:
        # This is one of the items I'm interested in!
        ....
    else:
        # Not interested in this item. And I'd prefer to let DynamoDB filter this out.
        continue

有没有办法让DynamoDB进行过滤,从而使上面的例子中的for循环过时了?

python-3.x amazon-web-services amazon-dynamodb boto3
1个回答
2
投票

遗憾的是,目前无法请求DynamoDB为您执行过滤计算,但您可以创建另一个属性,即两个属性的总和,您可以通过几种方法来实现这一目标。

  1. 在将项目写入DynamoDB时,可能会在代码中计算其他属性(last_check + check_interval)。
  2. 使用DynamoDB触发器创建其他属性(last_check + check_interval)

您可以使用任一选项在要过滤的项目上创建新属性。

© www.soinside.com 2019 - 2024. All rights reserved.