Django QuerySets 里的**kwargs: 动态创建ORM查询

Django的数据库API查询经常包含关键字参数。例如:

bob_stories = Story.objects.filter(title_contains='bob', subtitle_contains='bob', text_contains='bob',byline='bob')

下面展示如何按字典形式传递这些关键字参数:

bobargs = {'title_contains': 'bob', 'subtitle_contains': 'bob', 'text_contains': 'bob', 'byline_contains': 'bob'}
bob_stories = Story.objects.filter(**bobargs)

这样,就可以动态的创建字典了:

bobargs = dict((f + '_contains', 'bob') for f in ('title', 'subtitle', 'text', 'byline'))
bobstories = Story.objects.filter(**bobargs)

这样,就可以用这些技术来精简流水化查询中的多余部分,甚至有助于组装动态获取的过滤参数。

posted @ 2015-04-21 10:25  Mellcap  阅读(597)  评论(1编辑  收藏  举报