本文介绍了我如何知道ndb.Model.get_or_insert是否创建了一个新的实体或已有的实体?的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!
问题描述
对于下面的(损坏的)函数,如果实体被创建或更新,并且> 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是否创建了一个新的实体或已有的实体?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持!