2010-06-05 46 views

Respuesta

8

No existe un equivalente completo, pero get_or_insert es algo similar. La principal diferencia es que get_or_insert acepta key_name como búsqueda contra los filtros establecidos en get_or_create.

2

no he probado esto, pero debería ser algo como lo siguiente:

class BaseModel(db.Model): 
    @classmethod 
    def get_or_create(cls, parent=None, **kwargs): 
    def txn(): 
     query = cls.all() 
     if parent: 
     query.ancestor(parent) 
     for kw in kwargs: 
     query.filter("%s =" % kw, kwargs[kw]) 
     entity = query.get() 
     if entity: 
     created = False 
     else: 
     entity = cls(parent, **kwargs) 
     entity.put() 
     created = True 
     return (entity, created) 
    return db.run_in_transaction(txn) 

class Person(BaseModel): 
    first_name = db.StringProperty() 
    last_name = db.StringProperty() 

p, created = Person.get_or_create(first_name='Tom', last_name='Smith')