Django笔记十之values_list指定字段取值及distinct去重处理
这篇笔记将介绍 reverse、distinct、values 和 values_list 的用法。
本篇笔记目录如下:
- reverse()
- values()
- values_list()
- distinct()
- using()
1、reverse()
对 QuerySet 返回的结果进行反转,使用方法如下:
from blog.models import Blog
Blog.objects.filter(id__gte=2).reverse()
通过 reverse() 方法,可以使原本是某个顺序的数据顺序倒转返回。
2、values()
如果不使用 values() 方法,QuerySet 会返回 model 的所有字段,通过 obj.field_name 即可获取。
比如:
blog_obj = Blog.objects.all()[0]
blog_obj.name
如果我们在操作的时候仅仅想获取某一个或者某几个字段数据,则可以使用 values() 函数。
指定字段
如果是使用 values() 方法,则会仅仅返回相应字段的字典列表,比如:
name_dict_list = Blog.objects.values("name")
name_dict_list 数据则为:
<QuerySet [{'name': 'python3'}, {'name': 'hunter'}, {'name': 'a'}]>
name_dict_list 可以通过下标,访问到单条数据。
>>> name_dict_list[0]
{'name': 'python3'}
>>> name_dict_list[0].get('name')
'python3'
不指定字段
如果我们使用的时候不指定 values() 函数的参数,返回的则是该 model 所有字段的字典列表,比如说 Blog 这个 model 的字段为 id、name、tagline 三个,那么返回的是包含所有字段的字典列表,使用:
Blog.objecrs.filter(id=1).values()
返回的是:
<QuerySet [{'id': 1, 'name': 'hunter', 'tagline': 'asd'}]>
处理字段值返回
还可以对 values 指定的字段值进行处理后返回,比如全部都小写:
from django.db.models.functions import Lower
Blog.objects.values(lower_name=Lower('name'))
获取外键字段
也可以获取外键字段,指定外键加上双下划线和字段名即可:
Entry.objects.values('blog__name')
3、values_list()
values() 函数返回的结果是字典列表,列表里的元素是一个个的字典。
values_list() 函数返回的则是元组列表,效果如下:
Entry.objects.values_list('id', 'headline')
<QuerySet [(1, '123'), (2, 'wwwqeq')]>
如果我们需要获取的仅有一个字段,返回的也是一个元组列表,但是为了方便,我们也可以变成列表格式,加上 flat 参数即可。
注意: 这种情况仅存在于所需要获取的字段为一个的时候。
Entry.objects.values_list('id', flat=True)
<QuerySet [1, 2]>
这种方法比较好用,所以我常常在项目中使用。
4、distinct()
相当于 mysql 的 DISTINCT 的用法,这个用法需要用到前面介绍的 values() 方法。
使用方法如下:
Blog.objects.values("name").distinct()
5、using()
有时候,我们在 Django 项目中用到不止一个数据库,如果还用上了其他数据库,这些配置会在 settings.py 的 DATABASES 参数中配置。
比如:
DATABASES = {
'default': {
'ENGINE': 'django.db.backends.mysql',
'NAME': 'db1',
"USER": "root",
"PASSWORD": "xxx",
"HOST": "192.168.10.100",
"PORT": 3306,
},
'other': {
'ENGINE': 'django.db.backends.mysql',
'NAME': 'db2',
"USER": "root",
"PASSWORD": "xxx",
"HOST": "192.168.10.101",
"PORT": 3306,
}
}
那么如果我们要使用到 other 数据库的数据,则会用上 using()。
假设 TestModel 是属于 db2 数据库的,那么使用方法如下:
TestModel.objects.using('other').all()
其实我们一直使用的查询都是默认的指向 default 数据库的,所以就省略了 using() 用法,所以以下两种方法是等效的:
Blog.objects.all()
Blog.objects.using('default').all()
以上就是本篇笔记所有内容,接下来会介绍外键相关的 select_related、prefetch_related 等用法,它能够帮助我们在访问数据库的时候减少对数据库的访问次数。
本文首发于本人微信公众号:Django笔记。
原文链接:Django笔记十之指定字段取值及distinct去重处理
如果想获取更多相关文章,可扫码关注阅读:
Django笔记十之values_list指定字段取值及distinct去重处理的更多相关文章
- C# SQLiteDataReader获得数据库指定字段的值
获得数据库指定字段的值,赋给本地变量 (1)如下,获得userinfo数据表里的字段"userid"."orgid", string userid=" ...
- 把一个select查询结果插入到一个表(可选指定字段和值实例)
把一个select查询结果插入到一个表(可选指定字段和值实例) insert into bak (cc,yf) select cc,9 from ket insert into bak (cc,yf ...
- MySQL 自增字段取值
1 前言 本文来自回答思否网友的一个问题,这个网友新建了一张表,auto_increment_increment设为10,AUTO_INCREMENT主键起始值设为9, 当他插入数据的时候,发现主键值 ...
- Django笔记(2)Json字段处理
1) Django里面让Model用于JSON字段,添加一个JSONField自动类型如下: [python] view plain copy class JSONField(models.TextF ...
- 获取请求 header 中指定字段的值
private function getHeader($name) {//获取请求头中$name的值 $name = 'HTTP_' . $name; foreach ($_SERVER as $ke ...
- odoo开发笔记 -- tree视图按指定字段group_by分组显示
注意点: view视图文件中的搜索视图要放在action视图的前边. 在action视图中,要写search_view_id, 还有context, search_default_group_by_字 ...
- [转]Hibernate查询对象所有字段,单个字段 ,几个字段取值的问题
原文地址:http://www.ablanxue.com/prone_3552_1.html 1. 查询整个映射对象所有字段 Java代码 //直接from查询出来的是一个映射对象,即:查询整个映射对 ...
- Oracle批量更改所有表的字段取值_类型_原字段名
CREATE PROCEDURE 存储过程名称 is cursor c_tab is select * from user_tab_columns t r_tab user_tab_columns%r ...
- Entity Framwork(EF) 7——在Controller内获取指定字段的值
一.开发背景: 在用户登录的时候,验证用户和密码是否正确.验证通过后将用户名和用户ID保存下来以便后续数据更新时使用. 二.用户验证方法: 1.创建DBContext 对象. ApplicationD ...
- laravel 查询指定字段的值
$this->model->where('id',$id)->value('user');
随机推荐
- 狂神day3
放个假,有几天没有学习了,也好久没有更新博客了 IDEA使用 在上一次的时候,我们直接建立一个工程写了一个"helloworld"的java文件,今天首先说的是先建立一个空的工程, ...
- 20200924--图像相似度(奥赛一本通P92 5多维数组)
给出两幅相同大小的黑白图像(用0-1矩阵)表示,求它们的相似度.说明:若两幅图像在相同位置上的像素点颜色相同,则称它们在该位置具有相同的像素点.两幅图像的相似度定义为相同像素点数占总像素点数的百分比. ...
- java中锁的应用(ReentrantLock)
package com.xielu.test; public class explicit { private static Lock lock = new ReentrantLock(); priv ...
- scrollToFirstError失效解决方法
ant design 使用 设置scrollToFirstError = true,表单验证失败后却没有滚动到第一个错误字段 解决方法: 在button按钮中加入 html-type = 'submi ...
- Java 数据库表关联更新
SqlServer 关联更新语句: update a set a.pname = b.name from 表a a inner join 表b b on a.pid = b.id MySQL 关联更新 ...
- C# 类库 dll 读取配置文件信息
一:给 C# 类库 dll 添加配置文件并读取配置信息 效果: 1.给类库程序添加配置文件,并命名为:类库名.DLL.config 如上面效果图,类库为:API.dll ,那么其对应的类库配置文件为: ...
- CF1338E JYPnation
题意:给定一个竞赛图,且其中不包含任意一组三元环 $(a, b, c)$,满足 $a \to d$,$b \to d$,$c \to d$,求每个点两两之间的距离之和(若无法达到即为 $614n$). ...
- axel多线程下载
Axel 是一个轻量级下载程序,它和其他加速器一样,对同一个文件建立多个连接,每个连接下载单独的文件片段以更快地完成下载. Axel 通过打开多个 HTTP/FTP 连接来将一个文件进行分段下载,从而 ...
- webpack逆向之报错Cannot read properties of undefined (reading 'call')
经典报错 记录一下: 1: 缺少模块 补上 2.主模块无法调用子模块 有可能网站用的数组形式的模块包,你用的是对象,调用方法就要改变. 改写过程中 用的是对象方式: 那么3号包调用的4号包 ...
- 2020/5/14-笔记:Oracle数据库新建用户与给用户授权