3

我有两个模型:

class User(ndb.Model):
    email = ndb.StringProperty(required=True)
    name = ndb.StringProperty(required=True)

class Post(ndb.Model):
    created = ndb.DateTimeProperty(auto_now_add=True)
    message = ndb.TextProperty(required=True)
    user = ndb.KeyProperty(kind=User)

如果我想遍历 Post 模型中的一些帖子。我将如何访问用户模型中的“名称”字段?例如:

for post in posts:
    print post.message
    print post.user.name

所以我猜最后一行是不正确的。我尝试搜索并无法弄清楚。并补充说。有没有办法在 Jinja2 模板中访问该信息?

然后最后,我是不是错了?假设有 50 个帖子。我有 1 个查询来获取这 50 个帖子。每次循环时访问用户模型上的“名称”字段是否会成为一个额外的查询?所以51个查询??如果是这样,最好不要使用 KeyProperty 而只在每个帖子中存储用户数据(即使我有更多数据,如头像、user_id 等)?

4

1 回答 1

6

如果我没记错的话, aKeyProperty会返回给你 a ndb.Key。一旦你有了密钥,就很容易得到模型实例(key.get())。因此,在您的示例中,您将:

print post.user.get().name

至于在 jinja 模板中访问它——当然,它就像:

{% for post in posts %} 
{{ post.message }}
{{ post.user.get().name }}
{% endfor %}

是的,这将为您拥有的每个密钥与数据存储交互一次。如果您愿意,可以将其分解为一个数据存储交互:

keys = [p.user for p in posts]
users = ndb.get_multi(keys)
user_posts = zip(users, posts)

然后在您的 jinja 模板中:

{% for user, post in user_posts %}
{{ post.message }}
{{ user.name }}
{% endfor %}
于 2013-11-08T21:01:00.570 回答