- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我有两个模型:
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 等)?
最佳答案
如果我没记错的话,KeyProperty
会返回一个 ndb.Key
。获得 key 后,很容易获得模型实例 (key.get()
)。因此,在您的示例中,您将:
print post.user.get().name
就在 jinja 模板中访问它而言——当然,它就像这样:
{% for post in posts %}
{{ post.message }}
{{ post.user.get().name }}
{% endfor %}
是的,这将为您拥有的每个 key 与数据存储交互一次。如果您愿意,可以将其分解为一个数据存储交互:
keys = [p.user for p in posts]
users = ndb.get_multi(keys)
user_posts = zip(users, posts)
然后在您的神社模板中:
{% for user, post in user_posts %}
{{ post.message }}
{{ user.name }}
{% endfor %}
关于python - 在这种情况下如何正确使用 ndb KeyProperty?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19868410/
我有这两个模型: ################# ### Usergroup ### ################# class Usergroup(ndb.Model): group
我在理解实体和键在 Google App Engine NDB 中的工作方式时遇到一些问题。 我有一个 post 实体和一个 user 实体。如何将 post 上的 user_key 设置为 user
我有两个模型: class User(ndb.Model): email = ndb.StringProperty(required=True) name = ndb.StringPr
众所周知,应用引擎中的 keys_only 查询速度很快。 Google App Engine 现在可以运行“投影查询”,它可以只返回部分实体数据 https://developers.google.
我试图通过使用将字符串转换为相应类型的 Key 的自定义验证器来简化 ndb KeyProperties 的 JSON 序列化和反序列化。 想法是拥有这样的属性: def key_validator(
我刚刚开始使用 AppEngine 并使用 endpoints_proto_datastore 库。我的问题:当我尝试列出特定播放列表的所有 PlaylistItems 时,查询路径中的“播放列表”参
我已经查看了文档、文档和 SO 问题和答案,但仍在努力理解其中的一小部分。您应该选择哪个以及何时选择? 这是我到目前为止读过的内容(只是示例): ndb documentation movie dat
是否可以根据 KeyProperty 的祖先(父级)进行查询? EG,类似于以下内容: class Foo(ndb.Model): bar = ndb.KeyProperty() Foo.qu
我有一个简单的ndb模型如下: class TaskList(ndb.Model): title = ndb.StringProperty() description = ndb.Te
我有一些共享一组公共(public)属性的模型,我在其他模型继承的基本模型类中定义了这些属性: class BaseUser(ndb.Model): name = ndb.StringProp
在 AppEngine 的 NDB 数据存储中,似乎有两种方法可以将对象相互关联起来。有 ndb.KeyProperty 和 parents/ancestors keys .我对什么时候应该使用一个或
我有一个简单的场景,其中有一个 User 类,它具有 name、email 和 followers 属性。 class User(ndb.Model): name = ndb.StringPr
我正在尝试开发一个应用程序,其中 Student 实体通过它们的键添加到 Class 实体。所以在类里面,我可以有一个 List 的学生,可以通过他们的键来识别,这些键可以是 Integer 或 St
我正在使用 flask-appengine-template来自 kamalgill,我遇到了一个奇怪的问题。 我的 models.py 文件如下所示: from google.appengine.e
假设一个 NDB(版本 0.7 和 0.8)模型,其键可以是 None: class Test(model.Model): k = model.KeyProperty() value
ReferenceProperty 在处理两个模块之间的引用方面非常有帮助。狐狸例子: class UserProf(db.Model): name = db.StringProperty(r
有关于如何set的帖子, get , KeyProperty/StructuredProperty ,但没有任何内容告诉我如何使用 NDB 进行多对一建模。 我有两个模型: class Departm
我的问题是关于在 ndb 中建模一对多关系。我知道这可以通过(至少)两种不同的方式来完成:使用重复的属性或使用“外键”。我在下面创建了一个小例子。基本上我们有一篇文章可以有任意数量的标签。假设可以删除
我是一名优秀的程序员,十分优秀!