码迷,mamicode.com
首页 > 其他好文 > 详细

表查询之十三骚操作

时间:2019-09-19 00:46:50      阅读:63      评论:0      收藏:0      [点我收藏+]

标签:数字   方法   记录   ast   rev   字段   ever   models   计算   

在操作下面的数据之前,我们实现了创建好的数据表,这里主要演示下面的操作,不再细讲创建准备过程

1. all(): 查询所有结果

技术图片

 

 2. filter(**kwargs): 包含了与所给条件相匹配的对象

技术图片

 

 

<3> get(**kwargs): 返回与所给筛选条件相匹配的对象,返回结果有且只有一个,如果符合筛选条件的对象超过一个或者没有都会抛出错误。

技术图片

技术图片

 

 

<4> exclude(**kwargs): 它包含了与所给筛选条件不匹配的对象

技术图片

 

 

<5> values(*field): 返回一个ValueQuerySet——一个特殊的QuerySet,运行后得到的并不是一系列model的实例化对象,而是一个可迭代的字典序列

技术图片

 

 

<6> values_list(*field): 它与values()非常相似,它返回的是一个元组序列,values返回的是一个字典序列

技术图片

 

 

<7> order_by(*field): 对查询结果排序

 order_by(*field): 对查询结果排序(‘-id‘) / (‘price‘)
# print(models.Book.objects.order_by(‘price‘)) # 默认是升序
# print(models.Book.objects.order_by(‘-price‘)) # 加负号就是降序

<8> reverse(): 对查询结果反向排序,请注意reverse()通常只能在具有已定义顺序的QuerySet上调用(在model类的Meta中指定ordering或调用order_by()方法)

技术图片

 

<9> distinct(): 从返回结果中剔除重复纪录(如果你查询跨越多个表,可能在计算QuerySet时得到重复的结果。此时可以使用distinct(),注意只有在PostgreSQL中支持按字段去重。)

技术图片

 

<10> count(): 返回数据库中匹配查询(QuerySet)的对象数量

技术图片

 

 

<11> first(): 返回第一条记录

技术图片

 

 

<12> last(): 返回最后一条记录

技术图片

 

<13> exists(): 如果QuerySet包含数据,就返回True,否则返回False

技术图片

 

13个必会操作总结

返回QuerySet对象的方法有

all()

filter()

exclude()

order_by()

reverse()

distinct()

特殊的QuerySet

values()       返回一个可迭代的字典序列

values_list() 返回一个可迭代的元祖序列

返回具体对象的

get()

first()

last()

返回布尔值的方法有:

exists()

返回数字的方法有

count()

 

表查询之十三骚操作

标签:数字   方法   记录   ast   rev   字段   ever   models   计算   

原文地址:https://www.cnblogs.com/panshao51km-cn/p/11546394.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!