本文介绍了我如何知道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是否创建了一个新的实体或已有的实体?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持!

11-03 09:33