python测试开发django-14.查询表结果(超详细)
前言
django查询数据库的方法很多,不同的方法返回的结果也不太一样,本篇详细讲解关于查询的13个方法
- 返回对象是对象列表的: all(), filter(), exclude(), order_by(), reverse(), values(), values_list(), distinct()
- 返回结果是对象: get(), first(), last()
- 返回结果是布尔值: exists()
- 返回数字: count()
数据准备
接着前面的User表,测试数据如下
user_name |
psw |
|
---|---|---|
yoyo |
123456 |
283340479@qq.com |
yoyo2 |
111111 |
1 |
yoyo5 |
111111 |
0 |
可迭代对象queryset
查询整张表sql : select * from hello_user django里面查询数据库不需要写sql语句 ret=表的类名称.objects.all() 返回的是整个表的内容, 这里返回的是可迭代对象queryset,并没直接返回全部数据 如果想取出数据,需要用到for循环读取
from django.http import HttpResponse
from hello.models import User
def slec_all(request):
‘’‘取出User表里面user_name 、psw 、mail全部数据’‘’
users = ""
psws = ""
mails = ""
ret = User.objects.all()
# 返回queryset对象,可迭代
for i in ret:
users += " " + i.user_name # 获取user_name字段
psws += " " + i.psw # 获取psw字段
mails += " " + i.mail # 获取mail字段
return HttpResponse('''<p>查询user结果:%s</p>
<p>查询psw结果:%s</p>
<p>查询psw结果:%s</p>''' % (users, psws, mails))
在urls.py配置访问地址 url(r’^slec_all$’, testdb.slec_all),访问后得到的结果 查询user结果: yoyo yoyo2 yoyo5
查询psw结果: 123456 111111 111111
查询psw结果: 283340479@qq.com 1 0
筛选条件filter()
查询的时候添加删除条件,类似于SQL里面的where语句
select * from hello_user where user_name = “yoyo” and psw =”123456”
filter()查询的结果是可迭代对象,如果结果只有一个,可以通过下标取值。找不到的时候给个默认值null
from django.http import HttpResponse
from hello.models import User
def sele_filter(request):
'''获取user_name="yoyo" and psw="123456"对应的mail值
查找为空时,返回null'''
r = ""
ret = User.objects.filter(user_name="yoyo",
psw="123456")
try:
r = ret[0].mail
except:
r = "null"
return HttpResponse('<p>查询结果:%s</p>'%r)
在urls.py配置访问地址 url(r’^sele_filter$’, testdb.sele_filter),访问后得到的结果: 查询结果:283340479@qq.com
可迭代的字典序列values()
all()和filter()返回的都是可迭代的queryset序列,平常我们习惯获取字典的对象,可以用values()方法获取 User.objects.all().values(“user_name”, “mail”) 类似于SQL语句
select user_name, psw from hello_user
def sele_values(request):
'''可迭代的字典序列'''
r = ""
ret = User.objects.all().values("user_name", "mail")
for i in ret:
r += str(i)
return HttpResponse('<p>查询结果:%s</p>'%r)
在urls.py配置访问地址 url(r’^sele_values$’, testdb.sele_values),访问后得到的结果 查询结果:{‘user_name’: ‘yoyo’, ‘mail’: ‘283340479@qq.com’}{‘user_name’: ‘yoyo2’, ‘mail’: ‘1’}{‘user_name’: ‘yoyo5’, ‘mail’: ‘0’}
其它可迭代对象
- exclude() 它包含了与所给筛选条件不匹配的对象 调用者:objects管理器 返回queryset
查找用户名不是”yoyo”的数据 et=User.objects.exclude(user_name=”yoyo”)
- order_by() 对查询结果排序 由queryset对象调用,返回值是queryset
查询所有的数据,按mail字段排序,默认升序 ret=User.objects.all().order_by(“mail”) 查询所有的数据,按mail字段排序,前面加个-是代表降序 ret=User.objects.all().order_by(“-mail”)
如果有‘-’则代表着降序,没有则默认升序
- reverse() 对查询结果反向排序 由queryset对象调用,返回值是queryset
查询所有的数据,按mail字段排序,默认升序,查询结果反向排序,功能跟-mail一样 ret=User.objects.all().order_by(“mail”).reverse()
- values_list() 由queryset对象调用, 返回值是queryset 一个元组序列
和values差不多,只是这里返回的是元组 ret=User..objects.all().values_list(“user_name”, “mail”)
- distinct() 从返回结果中剔除重复纪录 由queryset对象调用,返回值是queryset
和sql里面的distinct去重一样 ret=User.objects.all().values(“user_name”, “mail”).distinct()
get()返回单个对象
django的get是从数据库的取得唯一个匹配的结果,返回一个对象。调用者:objects管理器 返回查询到model对象 (注意:查询结果有且只有一个才执行) 如果查询结果有多个,会报错MultipleObjectsReturned, 如果查询结果有0个,会报错DoesNotExist
from django.http import HttpResponse
from hello.models import User
def sele_get(request):
'''get返回唯一的查询结果'''
r = ""
ret = User.objects.get(user_name="yoyo")
r = ret.user_name + ret.mail
return HttpResponse('<p>查询结果:%s</p>'%r)
在urls.py配置访问地址 url(r’^sele_get$’, testdb.sele_get),访问后得到的结果 查询结果:yoyo283340479@qq.com
first()和last()
first(),last()方法: 返回第一条记录和返回最后一条记录 调用者:queryset 返回model对象
from django.http import HttpResponse
from hello.models import User
def sele_first_last(request):
'''查询第一个和最后一个记录'''
# fir = User.objects.all().order_by("mail")[0]
fir = User.objects.all().order_by("mail").first()
f = fir.mail
las = User.objects.all().order_by("mail").last()
l = las.mail
return HttpResponse('<p>查询第一个结果:%s</p> <p>查询最后结果:%s</p>' % (f, l))
在urls.py配置访问地址 url(r’^sele_first_last$’, testdb.sele_first_last),访问后得到的结果 查询第一个结果:0 查询最后结果:283340479@qq.com
exists()和count()
exists() 如果QuerySet包含数据,就返回True,否则返回False 由queryset对象调用 返回值布尔值
exists: 由queryset对象调用 返回值布尔值 is_exist=User.objects.all().exists()
count : 数数 由queryset对象调用 返回int
count :数数 :由queryset对象调用 返回int ret=User.objects.all().count()
- 《ios爆内存问题解决方案-OOMDetector组件》
- Linux/SUSE安装svn客户端的问题记录
- 《广研Android卡顿监控系统》
- 替换WordPress默认搜索为百度站内搜索(知更鸟主题可照搬)
- 《Android插件化技术——原理篇》
- 利用Centos或RedHat的iso镜像搭建本地yum仓库
- QUIC协议初探-iOS实践
- Golang语言社区--【基础知识】常量
- 服务器日志备份超节省空间的思路
- 《企鹅电竞weex实践—— iOS SDK的小九九》
- Linux操作系统DNS解析(nameserver)监控脚本
- 不给“爸爸”添麻烦 - iTOP iOS 动态库改造
- 移动SEO分享:php自动提交复合型Sitemap到百度搜索
- 《Android外部存储》
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- 多线程相关概念
- MySQL安装教程
- MapReduce之自定义OutputFormat
- 在TensorFlow中使用模型剪枝将机器学习模型变得更小
- 干货 | 滴滴 数据分析原来是这样做的!
- 数据链路层之PPP协议
- matplotlib基础绘图命令之boxplot
- MapReduce之GroupingComparator分组(辅助排序、二次排序)
- MySQL优化--概述以及索引优化分析
- MySQL优化--查询分析工具以及各种锁
- MySQL优化--MVCC
- Linux入门--基础命令
- Linux入门--权限管理、任务调度、磁盘管理
- 【Rust日报】2020-08-05 -- 如何在2020年进一步加快 Rust 编译器的速度
- Linux学习--网络、进程、服务、软件管理