我如何知道ndb.Model.get_or_insert是否创建了一个新的实体或已有的实体? [英] How do I know if ndb.Model.get_or_insert created a new entity or got an existing one?
本文介绍了我如何知道ndb.Model.get_or_insert是否创建了一个新的实体或已有的实体?的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!
问题描述
对于下面的(损坏的)函数,如果实体被创建或更新,并且 False $ c $,我想返回
True
否则。问题是我不知道 get_or_insert()
是否有一个现有的实体,或者插入了一个实体。有没有简单的方法来确定这一点?
class MyModel(ndb.Model):
def create_or_update(key,数据):
如果实体被创建或更新,则返回True,否则返回False。
current = MyModel.get_or_insert(key,data = data)
if(current.data!= data)
current.data = data
return True
return False
解决方案>
get_or_insert()
是一个简单的函数(尽管它的实现看起来很复杂,因为它试图处理不寻常的属性名称)。您可以轻松地自行编写它: @ ndb.transactional
def my_get_or_insert(cls,id,** kwds) :
key = ndb.Key(cls,id)
ent = key.get()
如果ent不是无:
return(ent,False)#False意思是未创建
ent = cls(** kwds)
ent.key = key
ent.put()
return(ent,True)#真正含义已创建
For the following (broken) function, I want to return True
if the entity was created or updated, and False
otherwise. The problem is that I do not know whether get_or_insert()
got an existing entity, or inserted one. Is there an easy way to determine this?
class MyModel(ndb.Model):
def create_or_update(key, data):
"""Returns True if entity was created or updated, False otherwise."""
current = MyModel.get_or_insert(key, data=data)
if(current.data != data)
current.data = data
return True
return False
解决方案
get_or_insert()
is a trivial function (although its implementation looks complex, because it tries to deal with unusual property names). You can easily write it yourself:
@ndb.transactional
def my_get_or_insert(cls, id, **kwds):
key = ndb.Key(cls, id)
ent = key.get()
if ent is not None:
return (ent, False) # False meaning "not created"
ent = cls(**kwds)
ent.key = key
ent.put()
return (ent, True) # True meaning "created"
这篇关于我如何知道ndb.Model.get_or_insert是否创建了一个新的实体或已有的实体?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!
查看全文