peewee - si hrát si s ORM.
definice modelu a vytváření schématu
Voní jako Django:
import Peewee
třída Blog (peewee.Model):
& Nbsp; title = peewee.CharField ()
& Nbsp; def __unicode __ (self):
& Nbsp; návrat self.title
třída Entry (peewee.Model):
& Nbsp; title = peewee.CharField (MAX_LENGTH = 50)
& Nbsp; obsah = peewee.TextField ()
& Nbsp; pub_date = peewee.DateTimeField ()
& Nbsp; blog = peewee.ForeignKeyField (Blog)
& Nbsp; def __unicode __ (self):
& Nbsp; return '% s:% s "% (self.blog.title, self.title)
vytvořit nějaké tabulky:
>>> Blog.create_table ()
>>> Entry.create_table ()
cizí klíče fungují jako Djangovo
& Nbsp; >>> b = Blog (title = "skrček velké dobrodružství")
& Nbsp; >>> b.save ()
& Nbsp; >>> e = vstup (title = "největší film někdy", content = "Ano!", Blog = b)
& Nbsp; >>> e.save ()
& Nbsp; >>> e.blog
& Nbsp;
& Nbsp; >>> for e v b.entry_set:
& Nbsp; ... print e.title
& Nbsp; ...
& Nbsp; největší film někdy?
bizarní dotazování
dotazy přijít ve 4 příchutích (Select / aktualizace / insert / smazat):
>>> For i in xrange (50):
... B = Blog (title = 'blog-% d "% i)
... B.save ()
... Pro jv xrange (i):
... E = vstup (title = "vstupní model% d"% j, blog = b)
... E.save ()
...
>>> [Obj.title pro obj v Blog.select ()., Kde (title__contains = "0")]
[U'blog-0 ", u'blog-10 ', u'blog-20', u'blog-30 ', u'blog-40"]
>>> [Obj.title pro obj v Blog.select (). Na stránky (3, 10)]
[U'blog-20 ', u'blog-21', u'blog-22 ', u'blog-23', u'blog-24 ',
& Nbsp; u'blog-25 ', u'blog-26', u'blog-27 ', u'blog-28', u'blog-29 ']
>>> [Obj.title pro obj v Blog.select (). Join (Entry) .where (title__contains = "entry-45 ')]
[U'blog-46 ', u'blog-47', u'blog-48 ', u'blog-49']
>>> Blog.select (). Join (Entry) .where (title__contains = "entry-29"). Počítat ()
20
Požadavky na :
- Python
Komentáře nebyl nalezen