删除DynamoDB表中具有辅助索引的元素时出现问题



我被卡住了,因为我在删除DynamoDB表中具有主键和全局辅助索引的元素时遇到问题(没有排序键(。

我得到以下错误:";所提供的密钥元素与模式"不匹配

我很绝望,我也试着在这个网站上查看其他帖子的答案,但我找不到任何关于删除的信息。

这是我的代码:

const AWS = require("aws-sdk");
const dynamo = new AWS.DynamoDB.DocumentClient();
exports.handler = async (event, context) => {
let body;
let statusCode = 200;
const headers = {
"Content-Type": "application/json",
"Access-Control-Allow-Origin": "*",
"Access-Control-Allow-Methods": "DELETE",
};
try {
switch (event.routeKey) {
case "DELETE /fragments/{id}":
await dynamo
.delete({
TableName: "fragment",
Key: {
id: event.pathParameters.id
}
})
.promise();
body = `Deleted fragment ${event.pathParameters.id}`;
break;
default:
throw new Error(`Unsupported route: "${event.routeKey}"`);
}
} catch (err) {
statusCode = 400;
body = err.message;
} finally {
body = JSON.stringify(body);
}
return {
statusCode,
body,
headers
};
};

TL;DRevent.pathParameters.idstring转换为number类型。

// convert id from string to number
Key: { id: parseInt(event.pathParameters.id, 10) }

DynamoDB.DocumentClientKey中的javascipt类型推断出关键模式类型。event.pathParameters.id是一个字符串,但您的密钥模式需要一个数字,因此DynamoDB返回一个模式不匹配错误。

我们如何知道event.pathParameters.idstring?API网关事件的lambda类型告诉我们:

// APIG event pathParameters
export interface APIGatewayProxyEventPathParameters {
[name: string]: string | undefined;
}

最新更新