DynamoDB:对GSI(全局二级索引)的查询不返回数据

时间:2017-11-14 13:23:30

标签: amazon-dynamodb aws-lambda serverless-framework

我正在使用无服务器框架来设置下表:

provider:
  name: aws
  runtime: nodejs6.10
  stage: dev
  region: ap-southeast-1
  environment:
    DYNAMODB_TABLE: "Itinerary-${self:provider.stage}"
    DYNAMODB_COUNTRY_INDEX: country_index
  iamRoleStatements:
    - Effect: Allow
      Action:
        - dynamodb:Query
        - dynamodb:Scan
        - dynamodb:GetItem
        - dynamodb:PutItem
        - dynamodb:UpdateItem
        - dynamodb:DeleteItem
      Resource: "arn:aws:dynamodb:${opt:region, self:provider.region}:*:table/${self:provider.environment.DYNAMODB_TABLE}"
    - Effect: Allow
      Action:
        - dynamodb:Query
        - dynamodb:Scan
        - dynamodb:GetItem
        - dynamodb:PutItem
        - dynamodb:UpdateItem
        - dynamodb:DeleteItem
      Resource: "arn:aws:dynamodb:${opt:region, self:provider.region}:*:table/${self:provider.environment.DYNAMODB_TABLE}/index/${self:provider.environment.DYNAMODB_COUNTRY_INDEX}"
resources:
  Resources:
    ItineraryTable:
      Type: 'AWS::DynamoDB::Table'
      DeletionPolicy: Retain
      Properties:
        AttributeDefinitions:
          -
            AttributeName: ID
            AttributeType: S
          -
            AttributeName: Country
            AttributeType: S
        KeySchema:
          -
            AttributeName: ID
            KeyType: HASH
        GlobalSecondaryIndexes:
          -
            IndexName: ${self:provider.environment.DYNAMODB_COUNTRY_INDEX}
            KeySchema:
              -
                AttributeName: Country
                KeyType: HASH
            Projection:
              ProjectionType: ALL
            ProvisionedThroughput:
              ReadCapacityUnits: 1
              WriteCapacityUnits: 1
        ProvisionedThroughput:
          ReadCapacityUnits: 1
          WriteCapacityUnits: 1
        TableName: ${self:provider.environment.DYNAMODB_TABLE}

现在,我可以通过ID从“数据库”中检索项目。但是,如果我尝试在GSI上进行“查询”,则不返回任何内容。没有失败,但我从来没有得到数据。

以下是我的查询:

const dynamoDb = new AWS.DynamoDB.DocumentClient();

var params = {
    TableName: process.env.DYNAMODB_TABLE, // maps back to the serverless config variable above
    IndexName: process.env.DYNAMODB_COUNTRY_INDEX, // maps back to the serverless config variable above
    KeyConditionExpression: "Country=:con",
    ExpressionAttributeValues: { ":con" : "Portugal" }
};

dynamoDb.query(params, (error, result) => {
    // handle potential errors
    if (error) {
        console.error(error);
        callback(null, {
            statusCode: error.statusCode || 501,
            headers: { 'Content-Type': 'text/plain' },
            body: 'Couldn\'t fetch the Itineraries'+error,
        });
        return;
    }
}

var json_result = JSON.stringify(result.Item);

我应该在这里补充说,如果我进行无过滤器“扫描”,我也无法获取数据。如果我尝试在AWS Dynamo Web门户上按索引(或其他方式)搜索项目,我会得到结果。

我无法弄清楚这里出了什么问题。任何人可以流下的光都会非常感激。

1 个答案:

答案 0 :(得分:3)

好的,所以我发现了问题。我发布的问题中缺少一个关键声明(因为我认为它不相关),但结果却出现了问题。

我只是使用以下方法对查询结果进行字符串化处理:

var json_result = JSON.stringify(result.Item);

以上适用于“获取”,但对于查询,则需要为result.Item s

var json_result = JSON.stringify(result.Items);

愚蠢的我。谢谢你的帮助!

P.S。我已将声明添加到原始问题中以明确