文档章节

django values(*field) values_list() 使用

jacked
 jacked
发布于 2015/10/14 01:00
字数 531
阅读 2721
收藏 0

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

当不传入参数时,返回这个model的所有字段

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

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

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

也可以加上filterfilter在前或者后面都是一样的

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

如果想把关联的字段也一起查出来OneToOneField, ForeignKey 和ManyToManyField 关系的都可以。
ManyToManyField 在Django1.3版本后才支持   LogTypeDef定义了一个appForeignKey

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

如果你只想拿到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)

 

© 著作权归作者所有

共有 人打赏支持
jacked
粉丝 0
博文 33
码字总数 5379
作品 0
朝阳
私信 提问
加载中

评论(2)

小狐濡尾
小狐濡尾

引用来自“z正小歪”的评论

太有用了~~~~哈哈哈哈
太有用了~~~~哈哈哈哈
太有用了~~~~哈哈哈哈
太有用了~~~~哈哈哈哈
太有用了~~~~哈哈哈哈
你们简直丧心病狂
z正小歪
z正小歪
太有用了~~~~哈哈哈哈
太有用了~~~~哈哈哈哈
太有用了~~~~哈哈哈哈
太有用了~~~~哈哈哈哈
太有用了~~~~哈哈哈哈
Django 1.11.3 发布,Python 的 Web 框架

Django 是一个高级的 Python Web 框架,旨在快速开发和简单,实用的设计。 Django 1.11.3 已发布,该版本修复了 1.11.2 中的一些 bug ,具体如下: Removed an incorrect deprecation warni...

王练
2017/07/03
1K
5
MongoEngine 0.6 发布

MongoEngine 0.6 发布了,MongoEngine由Python语言写成,提供一个很类似Django ORM的API 用于访问 MongoDB 数据库。 详细的改进记录: Added FutureWarning to inherited classes not decla...

红薯
2012/03/05
770
0
django model filter 条件过滤,及多表连接查询、反向查询

1.多表连接查询:当我知道这点的时候顿时觉得django太NX了。 class A(models.Model): name = models.CharField(u'名称') class B(models.Model): aa = models.ForeignKey(A) B.objects.filte......

best_raven
2015/08/24
0
0
django model filter 条件过滤,及多表连接查询、反向查询,某字段的distinct

1.多表连接查询:当我知道这点的时候顿时觉得django太NX了。 class A(models.Model): name = models.CharField(u'名称') class B(models.Model): aa = models.ForeignKey(A) B.objects.filte......

我的去哈哈
2014/03/19
0
0
Django 1.9.6 和 1.8.13 发布,Python Web 架构

Django 1.9.6 和 1.8.13 发布了。Django 是 Python 编程语言驱动的一个开源模型-视图-控制器(MVC)风格的 Web 应用程序框架。使用 Django,我们在几分钟之内就可以创建高品质、易维护、数据...

oschina
2016/05/03
1K
1

没有更多内容

加载失败,请刷新页面

加载更多

GIT 常用命令

Git图形化界面我用的还可以,但是命令就不太会了,索性和大家一起学习下Git命令的用法... 一般来说,日常使用只要记住下图6个命令,就可以了。但是熟练使用,恐怕要记住60~100个命令。 下面...

神勇小白鼠
19分钟前
1
0
可编程着色器---OpenGL渲染流水线

固定功能流水线 改变流水线结构 顶点着色器 片元着色器 几何着色器 曲面细分着色器

中国龙-扬科
21分钟前
1
0
qs.parse()、qs.stringify()、JSON.parse()、JSON.stringify()使用方法

qs.parse()、qs.stringify()、JSON.parse()、JSON.stringify()使用方法 1 qs.parse() 将url中的参数字符串转换成json对象。 var qs = require('qs');var url = 'method=query_sql_dataset_......

neumeng
34分钟前
3
0
需要注意的new Date 时区问题

(1)、Date中保存的是什么 Date对象里存的只是一个long型的变量,其值为自1970年1月1日0点至Date对象所记录时刻经过的毫秒数。调用Date对象getTime()方法就可以返回这个毫秒数。 (2)、时区...

为了美好的明天
40分钟前
1
0
java cache

##基本原理 ###核心内容 java cache API的5个核心接口:CachingProvider,CachingManager,Cache,Entry,ExpiryPolicy CachingProvider: 缓存提供者定义建立,配置,获得,管理,控制一个或者多...

zzx10
40分钟前
2
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部