表查询之十三骚操作

Posted panshao51km-cn

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了表查询之十三骚操作相关的知识,希望对你有一定的参考价值。

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

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()

 

以上是关于表查询之十三骚操作的主要内容,如果未能解决你的问题,请参考以下文章

ElasticStack系列之十三 & 联想补全策略

Linux命令:MySQL系列之十三--MySQL备份与还原(针对单张表SELECT备份)

Mysql数据库理论基础之十三 ---- LVM逻辑卷快照备份

Flask框架从入门到精通之模型查询(十三)

Flask框架从入门到精通之模型查询(十三)

跟我学Android之十三 SQLite数据库操作