2010-06-05 4 views

ответ

8

Нет полного эквивалента, но get_or_insert - это нечто похожее. Основные отличия в том, что get_or_insert принимает key_name как поиск по фильтрам, установленным в get_or_create.

2

Не проверял, но это должно быть что-то вроде следующего:

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