如何解决如何使用 PynamoDB 实例化具有本地二级索引的类模型?
我需要使用 pynamodb 库实例化一个使用本地二级索引的类模型,但出现错误。我的代码:
class MyIndex(LocalSecondaryIndex):
class Meta:
projection = AllProjection()
org_id = UnicodeAttribute(hash_key=True)
user_id = UnicodeAttribute(range_key=True)
class MyModel(Model):
class Meta:
table_name = 'my-table'
region = 'eu-west-1'
aws_access_key_id = '...'
aws_secret_access_key = '...'
org_id = UnicodeAttribute(hash_key=True)
doc_id = UnicodeAttribute(range_key=True)
user_index = MyIndex()
attr_one = NumberAttribute()
attr_two = UnicodeAttribute()
attr_three = NumberAttribute()
这是我第一次在 pynamodb 中使用索引(本地或全局)。文档实际上并没有给出使用索引实例化模型类的示例(我见过),只是模型/索引定义,然后是查询示例(我指的是 readthedocs here 和 { {3}})。
我第一次尝试测试它是这样的:
MyModel(
org_id = my_org_id,doc_id = my_doc_id,user_index = MyIndex(my_org_id,'abc123'),attr_one = 1,attr_two = 'foo',attr_three = 3,)
TypeError: __init__() takes 1 positional argument but 3 were given
删除第一个参数 my_org_id
给了我上面的错误 ...but 2 were given
。我也试过 user_index = 'abc123'
和 user_id = 'abc123'
,但在这两种情况下我都得到 ValueError: Attribute user_* specified does not exist
。
有人可以告诉我这是如何工作的,或者请指出一个工作示例的方向吗?
解决方法
我刚刚从示例中意识到 LSI 中使用的排序键也必须指定为使用 LSI 的表上的属性,以便使其正常工作,例如
class MyModel(Model):
class Meta:
table_name = 'my-table'
region = 'eu-west-1'
aws_access_key_id = '...'
aws_secret_access_key = '...'
org_id = UnicodeAttribute(hash_key=True)
doc_id = UnicodeAttribute(range_key=True)
user_index = MyIndex()
user_id = UnicodeAttribute() ### this was missing
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。