0

我正在尝试从没有任何索引的 dynamodb 数据库表中扫描失败的令牌计数。它从数据库返回 0。我怀疑它没有扫描完整的数据库。下面是我的方法和dynamoDBClient工作条件之一,它有连接细节。我在这里只发布扫描查询部分

public int getFailedAuthStatusCount() {

    Map<String,String> expressionAttributesNames = new HashMap<>();
      expressionAttributesNames.put("#status","auth_status");

    Map<String, AttributeValue> expressionAttributeValues = new HashMap<String, AttributeValue>();
    expressionAttributeValues.put(":val", new AttributeValue().withS("FAIL"));

    ScanRequest scanRequest = new ScanRequest()
              .withTableName("Token")
              .withFilterExpression("#status = :val")
              .withExpressionAttributeNames(expressionAttributesNames)
              .withExpressionAttributeValues(expressionAttributeValues);
    ScanResult scanResult = dynamoDBClient.scan(scanRequest); //client is working fine.
    return scanResult.getCount();
  }

这是回应。

{Items: [],Count: 0,ScannedCount: 1456,LastEvaluatedKey: {GUID={S: 0c4b281e6f9290c0fb3bf13f28c88fd,}, VENDOR={S: DELL,}},}

我的要求有什么问题?

4

1 回答 1

0

您的要求没有任何问题。扫描时,您必须继续重新提交请求,并将先前的请求LastEvaluatedKey作为下一个请求ExclusiveStartKey,直到您不再收到LastEvaluatedKey响应中的 a 。

您的第一个请求仅评估ScannedCount: 1456表中的第一项(≈ 1MB 数据)。

请参阅https://docs.aws.amazon.com/amazondynamodb/latest/developerguide/Scan.html#Scan.Pagination

在所有数据库环境中,表扫描都是缓慢且昂贵的。这就是为什么索引很重要的一个关键原因。由于可用的低级 API,DynamoDB 使这一点更加明显。

于 2018-12-06T15:14:40.300 回答