在DynamoDB中,原生数据类型包括String、Number、Binary、Boolean、Null、List和Map。AWS JavaScript SDK使用DynamoDB时,需要将数据类型转换为特定的格式。如果使用原始数据类型,则会出现类型错误导致调用失败。因此,我们需要使用相应的工具函数将数据转换为正确的格式。下面是一个将字符串转换为DynamoDB数据类型的示例代码:
const AWS = require('aws-sdk');
AWS.config.update({
region: 'us-east-1'
});
const dynamoDB = new AWS.DynamoDB();
// 将字符串转换为DynamoDB数据类型格式
function toDynamoDBType(value) {
if (typeof value === 'object' && !Array.isArray(value) && value !== null) {
return { M: mapToDynamoDB(value) };
} else if (Array.isArray(value)) {
return { L: listToDynamoDB(value) };
} else if (typeof value === 'string') {
return { S: value };
} else if (typeof value === 'number') {
return { N: value.toString() };
} else if (typeof value === 'boolean') {
return { BOOL: value };
} else if (value === null) {
return { NULL: true };
} else {
throw new Error(`Unsupported data type: ${typeof value}`);
}
}
// 将对象转换为DynamoDB数据类型格式
function mapToDynamoDB(map) {
const result = {};
for (let key in map) {
result[key] = toDynamoDBType(map[key]);
}
return result;
}
// 将数组转换为DynamoDB数据类型格式
function listToDynamoDB(list) {
return list.map(item => toDynamoDBType(item));
}
// 定义DynamoDB查询参数
const params = {
TableName: 'my-table',
Key: {
'id': toDynamoDBType('123')
}
};
// 调用DynamoDB查询
dynamoDB.getItem(params, (err, data) => {
if (err) {
console.error(err);
} else {
console.log(data);
}
});
上述代码中,toDynamoDBType
函数使用了条件语句和递归调用,将JavaScript原生类型转换为DynamoDB的数据类型格式。在查询操作中,我们将字符串'123'转换为DynamoDB数据类型格式。这样,AWS JavaScript SDK调用DynamoDB时就可以正确处理原生数据类型了。