文档章节

django values(*field) values_list() 使用

jacked
 jacked
发布于 2015/10/14 01:00
字数 531
阅读 7.3K
收藏 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
博文 35
码字总数 6093
作品 0
武汉
私信 提问
加载中

评论(2)

小狐濡尾
小狐濡尾

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

太有用了~~~~哈哈哈哈
太有用了~~~~哈哈哈哈
太有用了~~~~哈哈哈哈
太有用了~~~~哈哈哈哈
太有用了~~~~哈哈哈哈
你们简直丧心病狂
z正小歪
z正小歪
太有用了~~~~哈哈哈哈
太有用了~~~~哈哈哈哈
太有用了~~~~哈哈哈哈
太有用了~~~~哈哈哈哈
太有用了~~~~哈哈哈哈
[Django学习] Django基础(6)_Field lookups

一. 常见的三个函数   1. filter   2. exclude   3. get   4. dates(field, kind, order=’ASC’)     (1) field should be the name of a DateField of your model.     (......

osc_xl85dc6p
2018/07/05
2
0
Django ORM 操作mysql数据库

1、Django ORM操作MySQL数据库 a) 新建MySQL数据库叫dborm b)新建一个mysqlorm的项目 c) 在项目的settings下修改DATABASE 'default': { 'ENGINE': 'django.db.backends.mysql', 'NAME': 'db......

osc_h5z5wotn
2019/03/07
0
0
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
1.2K
5
Django框架——基础之模型系统(ORM相关操作)

------------恢复内容开始------------ 1.必定会的十三条! 1.1记忆方法一:(按字母顺序记忆) <1> all(): 查询所有结果 <2> count(): 返回数据库中匹配查询(QuerySet)的对象数量。 <3> di...

osc_0vv1t8wx
2019/11/28
2
0
Django学习笔记之Queryset详解

Django ORM用到三个类:Manager、QuerySet、Model。Manager定义表级方法(表级方法就是影响一条或多条记录的方法),我们可以以models.Manager为父类,定义自己的manager,增加表级方法;Que...

osc_yeuut7e4
2018/07/07
3
0

没有更多内容

加载失败,请刷新页面

加载更多

基于Centos7系统一键部署EFK服务

最近平台EFK版本均作了升级,平台采用EFK(ElasticSearch-7.6.2 + FileBeat-7.6.2 + Kibana-7.6.2)架构。这里建议三个组件主次版本保持一致。考虑到服务器比较多,所以写成脚本来批量部署。 ...

linuxprobe2020
48分钟前
23
0
检查键是否存在于JavaScript对象中? - Checking if a key exists in a JavaScript object?

问题: How do I check if a particular key exists in a JavaScript object or array? 如何检查JavaScript对象或数组中是否存在特定键? If a key doesn't exist, and I try to access it, ......

fyin1314
今天
27
0
jasypt-spring-boot提示Failed to bind properties

1 问题描述 在Spring Boot中使用jasypt-spring-boot进行加密,但是提示: Description:Failed to bind properties under 'spring.datasource.password' to java.lang.String: Reason:......

氷泠
今天
29
0
在git 2.13之前,只保存多个已更改的文件中的一个文件

问题: 如何在我的分支上只隐藏多个已更改文件中的一个? 解决方案: 参考一: https://stackoom.com/question/Cl3h/在git-之前-只保存多个已更改的文件中的一个文件 参考二: https://oldb...

技术盛宴
今天
30
0
SQL笔记:把Excel的数据导入MySQL中作运算

很多Excel用户都知道,Excel单个工作簿单张表存储的数据量很有限(旧版本月60多万条记录,新版本也才104万条不到),而且Excel中,因为自带各种格式与公式,兼之高度封装性等原因,导致Excel...

tengyulong
今天
15
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部