在Python / Google应用引擎中,我想将属性存储为键名,以节省资源并加快速度。但是我不知道如何获取键名列表。

例如,考虑数据模型:

class Book(db.Model):
    isbn = db.StringProperty() # Make this a key name instead.
    category = db.StringProperty()
    author = db.StringProperty()
    title = db.StringProperty()
    ...


现在,我们将键名设置为isbn而不是将其设置为属性名:

new_book = Book(category="fantasy,comedy", title="The Light Fantastic", author="Terry Pratchett", key_name=isbn_number)


我猜想,如果我能找到一种获取键名列表的方法,我会节省资源吗?例如,在检查收藏集中是否已存在特定书籍时。

这是正确的吗?如何获得键名列表?

如果不是这种情况,那么以下将是一个不错的妥协:

class ISBN(db.Model):
    isbn = db.StringProperty()

class Book(db.Model):
    isbn = db.ReferenceProperty(ISBN)
    category = db.StringProperty()
    author = db.StringProperty()
    title = db.StringProperty()
    ...


会节省资源/更快吗?

最佳答案

对于第一种方法,ISBN作为关键:

class Book(db.Model):
    #isbn is key, so it shouldn't be a property
    category = db.StringProperty()
    author = db.StringProperty()
    title = db.StringProperty()

new_book = Book(category="fantasy,comedy", title="The Light Fantastic", author="TerryPratchett", key_name=isbn_number)


然后获取所有ISBN的列表:

isbns = [b.name() for Book.all(keys_only=True)]

关于python - 如何在Python/Google App Engine中获取键名列表?,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/5407647/

10-12 16:24