2010-06-05 20 views

Répondre

8

Il n'y a pas d'équivalent complet, mais get_or_insert est quelque chose de similaire. Les principales différences sont que get_or_insert accepte key_name en tant que recherche sur les filtres définis dans get_or_create.

2

ai pas testé, mais il devrait être quelque chose comme ce qui suit:

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')