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)
相關文章
相關標籤/搜索