AppSync DynamoDb,提供的关键元素与架构不匹配

时间:2019-03-04 04:22:28

标签: amazon-dynamodb graphql aws-appsync

我正在尝试在AppSync中创建自定义查询类型,以查询默认ID以外的其他字段。

注意:我没有配置排序键或全局二级索引。

数据源已连接到DynamoDB GameStats表。该记录存在于表中,但是当我查询时,我得到“提供的键元素与架构不匹配”。

query getGameByMeetupId {
  getGameByMeetupId(meetupId: "259028625") {
    name
    field
    year
    month
  }
}

查询: getGameByMeetupId(meetupId: String): GameStats

请求映射模板:

    {
        "version": "2017-02-28",
        "operation": "GetItem",
        "key": {
            "meetupId": $util.dynamodb.toDynamoDBJson($ctx.args.meetupId)
        }
    }

响应映射模板: $utils.toJson($ctx.result)

错误消息:

{
  "data": {
    "getGameByMeetupId": null
  },
  "errors": [
    {
      "path": [
        "getGameByMeetupId"
      ],
      "data": null,
      "errorType": "DynamoDB:AmazonDynamoDBException",
      "errorInfo": null,
      "locations": [
        {
          "line": 2,
          "column": 3,
          "sourceName": null
        }
      ],
      "message": "The provided key element does not match the schema (Service: AmazonDynamoDBv2; Status Code: 400; Error Code: ValidationException; Request ID: MC71RFG6U85PBICS2OA714TLB7VV4KQNSO5AEMVJF66Q9ASUAAJG)"
    }
  ]
}

1 个答案:

答案 0 :(得分:3)

要使用DynamoDB Query,必须为分区键指定一个值。

您提到表格具有“默认ID”属性。那是您的分区键吗?如果是这样,您有两种选择:

1)将Query更改为Scan,并在meetupId属性上指定过滤器

2)添加一个GSI,将meetupId设置为分区键,然后更新已经必须以GSI(而不是基表)为目标的Query