django values(*field) values_list() 使用

这个方法返回的是ValuesQuerySet,是QuerySet 的子类,也就是说,你能够用QuerySet里的方法。 须要注意的是,返回的不是list,不要直接当list来用了。对ValuesQuerySet遍历,每个元素是“字典”dict。 python

当不传入参数时,返回这个model的全部字段 app

AppDef.objects.values()  [{'creator': u'admin', 'apptype_name': u'uc3g', 'apptype_chn_name': u'3G\u95e8\u6237', 'note': u'', ...},...] url

当传入参数时,只会列出你指定的参数 spa

AppDef.objects.values('apptype_name')  [{'apptype_name': u'uc3g'},...] code

也能够加上filterfilter在前或者后面都是同样的 class

AppDef.objects.filter(pk=1).values('apptype_name') AppDef.objects.values('apptype_name').filter(pk=1) object

若是想把关联的字段也一块儿查出来OneToOneField, ForeignKey 和ManyToManyField 关系的均可以。
ManyToManyField 在Django1.3版本后才支持   LogTypeDef定义了一个appForeignKey
select

LogTypeDef.objects.filter(pk=6).values('pk', 'app__apptype_name')  [{'pk': 6L, 'app__apptype_name': u'wapsearch'}] model

若是你只想拿到app_id,能够这样,下面三种方法都是同样的,只是返回的结果名字对应你的查询语句 遍历

LogTypeDef.objects.filter(pk=6).values('pk', 'app_id')  LogTypeDef.objects.filter(pk=6).values('pk', 'app')  LogTypeDef.objects.filter(pk=6).values('pk', 'app__id')

注意在关联关系为多对多的时候,它只会帮你一条一条的列出来,而不会帮你合并为一个list
例如会返回类型的结果:同一个pk并不会帮你合并app_id

[{pk: 6, app_id: 2}, {pk: 6, app_id: 3}]

2. 注意事项

当同时使用distinct()和values(),须要注意order_by() (或者默认 model ordering) ,会自动加入select 中做为distinct项,因此返回的结果你觉得是重复的,实际上是order by的字段没列出来。
若是在extra() 以后用values(),必定要把extra用到的字段也加进来;若是extra()在values()以后,extra的字段会自动加进select。

3. Values_list

values同样,只是默认返回的不是字典而是元组;能够增长flat=True参数,返回某个字段的列表,例子以下:

Case_images.objects.filter(case=case_id).order_by('-created_time').values_list('url',flat=True)
相关文章
相关标签/搜索