当我试图从表中获取项目时,它会打印此错误
botocore.exceptions.ClientError:调用GetItem操作时发生错误(ValidationException):提供的键元素与架构不匹配
这是我的密码
dynamodb = boto3.resource('dynamodb')
table = dynamodb.Table('testDynamodb')
response = table.get_item(Key={'userId': "user2873"})
item = response['Item']
print(item)
有什么想法吗?谢谢
我也有同样的问题。解决办法是:
创建表时,在schema
中仅将usrID
定义为Hash
键。[我是指单个主键]
然后,您可以根据usrID
调用get item。如果在表Schema
中将usrId
和createdAt
定义为Hash
和Sort
键。[我指的是复合主键]在调用getItem时必须同时提供这两个键。
另一件工作是下面的代码:
from boto3.dynamodb.conditions import Key
result = table.query(
KeyConditionExpression=Key('userId').eq('user2873')
)
表模式定义了哈希键和排序键。当使用DynamoDB GetItem你必须提供他们两个,这里是一个摘录从留档
对于主键,必须提供所有属性。例如,对于一个简单的主键,您只需要为分区键提供一个值。对于复合主键,必须同时提供分区键和排序键的值。
response = table.get_item(Key={'userId': "user2873", 'createdAt': "1489376547"})
我正在尝试使用boto3从DynamoDB查询项目。 该表如下所示: DynamoDB表 我运行的代码是: 我错过了什么?
我在DynamoDB中创建了一个表“user\u info”,其中有一个主哈希键“user\u id”(String),没有范围键。然后,我创建了2个AWS lambda函数来插入和查询项目。我可以将项目插入表中,但查询表时,它会返回: ValidationException:提供的键元素与架构不匹配。 我的查询功能: 我一直得到这个例外: 自从 1) 我只有一个哈希主键。 2)user_id定义
我在Boto3/DynamoDB BatchGetItem操作中遇到困难。我将非常感谢任何帮助或指导!我对python/aws非常陌生,如果这是一个新手问题,那么很抱歉在高级版。 当我执行该操作时,会出现以下错误: 这是我的代码: 这是表中项目的屏幕盖。 这是表详细信息的屏幕盖,显示分区键为'item_ID',是'string' 以下是完整的错误消息:
我正在尝试使用AWS Lambda函数将csv数据从S3写入DynamoDB。我当前收到以下错误“BatchWriteItem操作:提供的键元素与架构不匹配”。 这个问题有快速解决办法吗? 错误如下所示: 调用BatchWriteItem操作时发生错误(ValidationExc0019):提供的键元素与模式不匹配:ClientError Traceback(最近的调用最后一次): 文件“/var
我正在尝试更新Dynamodb表用户中的一项。我尝试了许多不同的方法,但总是收到相同的错误消息: 提供的键元素与架构不匹配 项目的创建与查询一样有效,但更新不起作用。当我在DynamoDB上检查时,用户创建得很好: 下面是表格信息: 表名:用户 主分区键:电子邮件(字符串) 主排序键:注册(编号) 下面是代码(从lambda调用): 你知道我的代码中可能有什么错误吗?
我正在尝试使用boto和python删除DynamoDB表中的大量项。我的表是用主键作为设备ID(想想MAC地址)设置的。表中有多个设备ID条目,因为主键是UNIX时间戳。 从我的阅读代码应该工作: 来源:http://docs.pythonboto.org/en/latest/dynamodb2_tut.html#batch-writing 但是,它返回“提供的键元素与架构不匹配”作为错误消息。