80.常用的返回QuerySet对象的方法使用详解:order_by
order_by: 将模型生成的表按照某个字段进行排序,默认情况下,按照升序的顺序排序,如果想要按照降序的顺序排序可以在字段的前面加一个“-”,加一个负号就可以进行反转。
models.py文件中示例代码如下:
from django.db import models
class Category(models.Model):
name = models.CharField(max_length=100)
rating = models.FloatField(null=True)
class Meta:
db_table = 'category'
class Article(models.Model):
title = models.CharField(max_length=100)
content = models.TextField()
category = models.ForeignKey('Category', on_delete=models.CASCADE, null=True)
create_time = models.DateTimeField(auto_now_add=True, null=True)
def __str__(self):
return "<(Article: id: %s,title: %s, content: %s)>" % (self.id, self.title, self.content)
class Meta:
db_table = 'article'
mysql数据库表中article表和category表中的数据如下所示:


1.order_by: 传递一个字段名,对表中的数据进行排序,默认情况对所有的数据做升序的排序操作。示例代码如下:
from django.db.models import F, Q
from django.db improt connection
from .models import Article, Category
from django.http import HttpResponse
def index(request):
articles = Article.objects.order_by('create_time')
for article in articles:
print("%s, %s, %s" % (article.id, article.title, article.create_time))
print(connection.queries)
return HttpResponse("success!")
2. order_by: 传递一个字段名,对表中所有数据做降序操作,可以通过在字段名前面添加一个负号来解决。示例代码如下:
from django.db.models import F, Q
from django.db improt connection
from .models import Article, Category
from django.http import HttpResponse
def index(request):
articles = Article.objects.order_by('-create_time')
for article in articles:
print("%s, %s, %s" % (article.id, article.title, article.create_time))
print(connection.queries)
return HttpResponse("success!")
3. order_by:传递多个参数,首先按照category_id从小到大进行排序,之后按照create_time从大到小排序。示例代码如下:
from django.db.models import F, Q
from django.db improt connection
from .models import Article, Category
from django.http import HttpResponse
def index6(request):
# 将article表首先按category_id进行从小到大排序,之后在按create_time从大到小排序
articles = Article.objects.order_by('category', '-create_time')
for article in articles:
# 遍历每一个对象
print("%s, %s, %s" % (article.id, article.category, article.create_time))
# 查看原生sql语句
print(connection.queries)
return HttpResponse("success!")
注意:如果需要按照多个字段进行排序,不能使用多个order_by()语句链式调用实现,如果使用多个order_by语句,最后的排序结果是按最后一个order_by()语句传递的字段名进行排序的结果。
def index6(request):
# 将article表首先按category_id进行从小到大排序,之后在按create_time从大到小排序
# 不能使用链式的多个order_by()语句。这样的结果只会使用最后一个order_by语句的条件进行排序
articles = Article.objects.order_by('category').order_by('create_time')
for article in articles:
print("%s, %s, %s" % (article.id, article.title, article.create_time))
print(connection.queries)
return HttpResponse("success!")
4. 同样,在排序的时候可以在模型的定义的时候指定Meta类,给Meta类中的ordering属性传递一个列表,数据库表中的字段的顺序就是表中的字段排序的顺序
5.通过外键的关系映射出的关联表之间的排序。比如,首先将article表中的文章按创建的时间从大到小排序,之后按照文章的分类的评分从小到大进行排序。示例代码如下:
def index6(request):
# 关联表之间的排序
# 首先将article表中的文章按创建的时间从大到小排序,之后按照文章的分类的评分从小到大进行排序
articles = Article.objects.order_by('-create_time', 'category__rating')
for article in articles:
print("%s, %s, %s" % (article.id, article.category.rating, article.create_time))
print(connection.queries)
return HttpResponse("success")
查询结果为:
2, 3.4, 2020-02-05 03:04:59.860556+00:00
1, 3.6, 2020-02-05 03:04:59.860556+00:00
4, 3.6, 2020-02-05 03:04:59.860556+00:00
3, 4.8, 2020-02-05 03:03:30.860556+00:00
原生sql语句:SELECT article.id, article.title, article.content, article.category_id, article.create_time FROM article LEFT OUTER JOIN category ON (article.category_id = category.id) ORDER BY article.create_time DESC, category.rating ASC
6.将分类中图书的数量从多到少进行排序,示例代码如下:
from django.db import Count
def index6(request):
# 将分类按分类中的图书的数量从多到少进行排序
# 首先统计出每个分类中图书的数量,并且添加一个图书数量的字段
categories = Category.objects.annotate(article_nums=Count('article__category__id')).order_by('-article_nums')
for category in categories:
print("%s/%s/%s" % (category.id, category.name, category.article_nums))
print(categories.query)
return HttpResponse("success!")
打印出结果如下所示:
1/最新文章/2
2/最热文章/1
3/高评分文章/1
django底层执行的sql语句为: SELECT category.id, category.name, category.rating, COUNT(article.category_id) AS article_nums FROM category LEFT OUTER JOIN article ON (category.id = article.category_id) GROUP BY category.id ORDER BY article_nums DESC
80.常用的返回QuerySet对象的方法使用详解:order_by的更多相关文章
- 84.常用的返回QuerySet对象的方法使用详解:select_related, prefetch_related
1.select_related: 只能用在一对多或者是一对一的关联模型之间,不能用在多对多或者是多对一的关联模型间,比如可以提前获取文章的作者,但是不能通过作者获取作者的文章,或者是通过某篇文章获取 ...
- 82.常用的返回QuerySet对象的方法使用详解:all,select_related
1. all: 返回这个ORM模型的QuerySet对象. articles = Article.objects.all() print(articles) 2.select_related: 查找数 ...
- 85.常用的返回QuerySet对象的方法使用详解:defer,only
defer(),only(): 这两个方法都会返回一个"QuerySet"对象,并且这个"QuerySet"中装的是模型,不像values()和values_l ...
- 81.常用的返回QuerySet对象的方法使用详解:values和values_list
values: 指定提取的数据库表中的字段值,如果不指定任何的字段名的话,默认情况下会提取所有的字段值.但是需要注意的是使用values返回的QuerySet对象中包括的是一个个的字典. 1.提取与A ...
- 79.常用的返回QuerySet对象的方法使用详解: filter, exclude,annotate
返回新的QuerySet的常用方法: 1.filter: 将满足条件的数据提取出来,返回一个新的QuerySet 以下所使用的模型article,category,定义模型models.py文件中,示 ...
- asp.net中C#对象与方法 属性详解
C#对象与方法 一.相关概念: 1.对象:现实世界中的实体 2. 类:具有相似属性和方法的对象的集合 3.面向对象程序设计的特点:封装 继承 多态 二.类的定义与语法 1.定义类: 修饰符 类名称 ...
- 2020你还不会Java8新特性?方法引用详解及Stream 流介绍和操作方式详解(三)
方法引用详解 方法引用: method reference 方法引用实际上是Lambda表达式的一种语法糖 我们可以将方法引用看作是一个「函数指针」,function pointer 方法引用共分为4 ...
- js对象浅拷贝和深拷贝详解
js对象浅拷贝和深拷贝详解 作者:i10630226 字体:[增加 减小] 类型:转载 时间:2016-09-05我要评论 这篇文章主要为大家详细介绍了JavaScript对象的浅拷贝和深拷贝代码,具 ...
- Underscore _.template 方法使用详解
为什么用「void 0」代替「undefined」 undefined 并不是保留词(reserved word),它只是全局对象的一个属性,在低版本 IE 中能被重写. 事实上,undefined ...
随机推荐
- 值得一学的C语言
P1085 不高兴的津津 #include <stdio.h> int main( ) { int a,b; int max=0; int result; for (int i = 0; ...
- HTML 5 <blockquote><p>的分工与合作
一提到文档标签,大家首先想到的就是p,那如果要实现缩进及间距,还得使用margin,padding及text-indent等css样式. 但现在html5的一个新标签解决了以上所有问题,它可以自缩进和 ...
- leetcode746 Min Cost Climbing Stairs
""" On a staircase, the i-th step has some non-negative cost cost[i] assigned (0 inde ...
- 关于torchvision.models中VGG的笔记
VGG 主要有两种结构,分别是 VGG16 和 VGG19,两者并没有本质上的区别,只是网络深度不一样. 对于给定的感受野,采用堆积的小卷积核是优于采用大的卷积核的,因为多层非线性层可以增加网络深度来 ...
- ACM-挑战题之排列生成
题目描述:挑战题之排列生成 一自然数N,设N为3,则关于N的字典序排列为123,132,213,231,312,321.对于一个自然数N(1<= N <= 9 ) , 你要做的便是生成它的 ...
- 基础知识 SafeSEH DEP ASLR SEHOP
大多是0day书上抄的 1.SafeSEH 机制: 首先:内存中有SEH表的备份(加密过的) 在调用异常出来函数前,RtlDispatchException()函数中的行为: Ⅰ.检查异常处理链是否位 ...
- S7-300位逻辑指令仿真练习 停车场
第三章 S7-300 指令应用 位逻辑指令 M存储器 在PLC中M存储区(也称位存储区,又称内部存储器标志位(M)存储器区),它属于系统存储区.在你选定具体的CPU型号后,可以查看CPU的技术规格,其 ...
- 中兴将用“加减乘除”建立理想 5G 网络
6 月 28 日,MWC 2019 上海展期间,中兴通讯执行董事.总裁徐子阳发表演讲表示,面对 5G 建网大势,要看破大势,不破不立.为此中兴将用“加减乘除”建立理想 5G 网络. 何为“加减乘除 ...
- 关于连接查询主要是左右连接查询中,where和on的区别
工作中,今天用到左连接查询,我自己造的数据,需要根据条件进行筛选,但是筛选不符合我的要求,最终发现是左右连接中where和on的区别,在作怪,工作中用的表关联太多,我下面简化要点,仅仅把注意点写个简单 ...
- <老古董>线性支持向量机中的硬间隔(hard margin)和软间隔(soft margin)是什么
_________________________________________________________________________________________________ Th ...