2010-06-05 12 views

Antwort

8

Es gibt keine vollständige Entsprechung, aber get_or_insert ist etwas ähnliches. Der Hauptunterschied besteht darin, dass get_or_insertkey_name als Nachschlag gegen Filter akzeptiert, die in get_or_create eingestellt sind.

2

habe nicht getestet, aber es sollte in etwa wie folgt sein:

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