gpt4 book ai didi

amazon-web-services - Dynamodb- 添加非关键属性

转载 作者:行者123 更新时间:2023-12-04 11:02:44 30 4
gpt4 key购买 nike

我想将数据插入到 dynamodb 本地。但是,我只有一个关键属性和多个非关键属性。

{
'id':'99876983ydbhdu3739',
'category':'Spa',
'latitude':'33.498',
'longitude':'32.332',
'name':'Studio'
}

我有多个这样的值。这是一个记录,我想插入的一个例子。以下是我正在尝试的内容:
table = dynamodb.create_table(
TableName='Trial',
KeySchema=[
{
'AttributeName': 'facebook_id',
'KeyType': 'HASH' #Sort key
},
{
'AttributeName': 'latitude',
'KeyType': 'RANGE' #Sort key
},

],
AttributeDefinitions=[
{
'AttributeName':'id',
'AttributeType':'S'
},
{
'AttributeName': 'category',
'AttributeType': 'S'
},
{
'AttributeName': 'latitude',
'AttributeType': 'S'
},
{
'AttributeName': 'longitude',
'AttributeType': 'S'
},
{
'AttributeName': 'name',
'AttributeType':'S'
}

],
ProvisionedThroughput={
'ReadCapacityUnits': 10,
'WriteCapacityUnits': 10
}
)

我收到以下错误:

An error occurred (ValidationException) when calling the CreateTable operation: The number of attributes in key schema must match the number of attributesdefined in attribute definitions.

最佳答案

您可以在创建表时单独使用 HASH 和 RANGE 键属性创建表。 DynamoDB 不希望定义所有其他属性,因为 DynamoDB 是一个键值对表。请尝试以下代码。您应该能够创建表。

插入项目时,您可以根据需要包含任何属性。

创建表:-

var AWS = require("aws-sdk");

AWS.config.update({
region : "us-west-2",
endpoint : "http://localhost:8000"
});

var dynamodb = new AWS.DynamoDB();

var params = {
TableName : "Trail",
KeySchema : [ {
AttributeName : "facebook_id",
KeyType : "HASH"
}, //Partition key
{
AttributeName : "latitude",
KeyType : "RANGE"
} //Sort key
],
AttributeDefinitions : [ {
AttributeName : "facebook_id",
AttributeType : "N"
}, {
AttributeName : "latitude",
AttributeType : "S"
} ],
ProvisionedThroughput : {
ReadCapacityUnits : 10,
WriteCapacityUnits : 10
}
};

dynamodb.createTable(params, function(err, data) {
if (err) {
if (err.code === "ResourceInUseException"
&& err.message === "Cannot create preexisting table") {
console.log("message ====>" + err.message);
} else {
console.error("Unable to create table. Error JSON:", JSON
.stringify(err, null, 2));
}

} else {
console.log("Created table. Table description JSON:", JSON.stringify(
data, null, 2));
}
});

创建项目:-
var AWS = require("aws-sdk");

AWS.config.update({
region : "us-west-2",
endpoint : "http://localhost:8000"
});

var docClient = new AWS.DynamoDB.DocumentClient();

var table = "Trail";

var params = {
TableName : table,
Item : {
"facebook_id" : 1,
"latitude" : 'lat',
"longitude" : 'long',
"name" : 'facebook',
"category" : 'social_media'
}
};

console.log("Adding a new item...");
docClient.put(params, function(err, data) {
if (err) {
console.error("Unable to add item. Error JSON:", JSON.stringify(err,
null, 2));
} else {
console.log("Added item:", JSON.stringify(data, null, 2));
}
});

关于amazon-web-services - Dynamodb- 添加非关键属性,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/38151687/

30 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com