返回新的QuerySet的常用方法:

1.filter: 将满足条件的数据提取出来,返回一个新的QuerySet

以下所使用的模型article,category,定义模型models.py文件中,示例代码为:
from django.db import models

class Category(models.Model):
name = models.CharField(max_length=100) 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'
(1). 在使用QuerySet进行查找的时候,可以执行多种操作比如filter()方法进行id的过滤完成后,还要根据某个字段进行排序,那么这一系列的操作我们可以通过一个非常专业的操作叫做“链式调用”的方式进行。比如,要从文章列表中获取id大于等于2的,并且提取之后将结果根据发布的时间进行排序(order_by()),示例代码如下:
首先查看数据库表中数据的信息:

from django.http import HttpResponse
from .models import Article
from django.db.models.manager import Manager
from django.db.models.query import QuerySet def index4(request):
articles = Article.objects.filter(id__gte=2).order_by("create_time")
for article in articles:
print("%s, %s, %s" % (article.title, article.content, article.create_time))
print(articles.query)
return HttpResponse("success !")
打印出结果如下:

3, 钢铁是怎样炼成的, 你好, 2020-02-05 03:03:30.860556+00:00

2, Hello World, 大家好, 2020-02-05 03:04:59.860556+00:00

4, 中国吸引力, 精彩极了, 2020-02-05 03:04:59.860556+00:00

由输出的结果,我们可以看出文章已经按时间的顺序进行排序了,默认情况下是按照降序的顺序。

打印出django底层所执行的原生SQL语句:

SELECT article.id, article.title, article.content, article.category_id, article.create_time FROM article WHERE article.id >= 2 ORDER BY article.create_time ASC。

可以看出我们的查询条件已经被翻译成了WHERE article.id >= 2 ORDER BY article.create_time ASC

(2). 如果想要将id大于等于3,但是不等于4的文章查找出来,就可以使用Q表达式和~来实现。注意:一定不要用"xxx != xxx"来实现,因为这样在python中会返回bool型的True或者是False。示例代码如下:
from django.db.models import Q
from django.http import HttpResponse
from .models import Article, Category
from django.db.models.query import QuerySet
from django.db.models.manager import Manager def index5(request):
articles = Article.objects.filter(id__gte=3).filter(~Q(id=4))
# articles = Article.objects.filter(id__gte=3).exclude(id=4)
for article in articles:
print("%s, %s, %s" % (article.id, article.title, article.create_time))
print(articles.query)
return HttpResponse('success!')
打印出执行的结果:

3, 钢铁是怎样炼成的, 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 WHERE (article.id >= 3 AND NOT (article.id = 4))

2. exclude:排除满足条件的数据,返回一个新的QuerySet。示例代码如下:

def index5(request):
articles = Article.objects.exclude(title__icontains='hello')
for article in articles:
print("%s, %s, %s" % (article.id, article.title, article.create_time))
print(articles.query)
return HttpResponse('success!')
打印出结果如下所示:

3, 钢铁是怎样炼成的, 2020-02-05 03:03:30.860556+00:00

4, 中国吸引力, 2020-02-05 03:04:59.860556+00:00

django底层执行的sql语句:SELECT article.id, article.title, article.content, article.category_id, article.create_time FROM article WHERE NOT (article.title LIKE %hello%)

3. annotate:给QuerySet中的每个对象都添加一个使用查询表达式(聚合函数,F表达式,Q表达式,Func表达式等)的字段,示例代码如下:

def index5(request):
articles = Article.objects.annotate(category_name=F("category__name"))
for article in articles:
print("%s, %s, %s" % (article.id, article.title, article.category_name))
print(articles.query)
return HttpResponse('success!')
打印出返回的结果如下:

1, Hello, 最新文章

2, Hello World, 最热文章

3, 钢铁是怎样炼成的, 高评分文章

4, 中国吸引力, 高评分文章

SELECT article.id, article.title, article.content, article.category_id, article.create_time, category.name AS category_name FROM article LEFT OUTER JOIN category ON (article.category_id = category.id)

79.常用的返回QuerySet对象的方法使用详解: filter, exclude,annotate的更多相关文章

  1. 82.常用的返回QuerySet对象的方法使用详解:all,select_related

    1. all: 返回这个ORM模型的QuerySet对象. articles = Article.objects.all() print(articles) 2.select_related: 查找数 ...

  2. 85.常用的返回QuerySet对象的方法使用详解:defer,only

    defer(),only(): 这两个方法都会返回一个"QuerySet"对象,并且这个"QuerySet"中装的是模型,不像values()和values_l ...

  3. 84.常用的返回QuerySet对象的方法使用详解:select_related, prefetch_related

    1.select_related: 只能用在一对多或者是一对一的关联模型之间,不能用在多对多或者是多对一的关联模型间,比如可以提前获取文章的作者,但是不能通过作者获取作者的文章,或者是通过某篇文章获取 ...

  4. 81.常用的返回QuerySet对象的方法使用详解:values和values_list

    values: 指定提取的数据库表中的字段值,如果不指定任何的字段名的话,默认情况下会提取所有的字段值.但是需要注意的是使用values返回的QuerySet对象中包括的是一个个的字典. 1.提取与A ...

  5. 80.常用的返回QuerySet对象的方法使用详解:order_by

    order_by: 将模型生成的表按照某个字段进行排序,默认情况下,按照升序的顺序排序,如果想要按照降序的顺序排序可以在字段的前面加一个"-",加一个负号就可以进行反转. mode ...

  6. asp.net中C#对象与方法 属性详解

    C#对象与方法 一.相关概念: 1.对象:现实世界中的实体 2. 类:具有相似属性和方法的对象的集合 3.面向对象程序设计的特点:封装  继承 多态 二.类的定义与语法 1.定义类: 修饰符 类名称 ...

  7. js对象浅拷贝和深拷贝详解

    js对象浅拷贝和深拷贝详解 作者:i10630226 字体:[增加 减小] 类型:转载 时间:2016-09-05我要评论 这篇文章主要为大家详细介绍了JavaScript对象的浅拷贝和深拷贝代码,具 ...

  8. 2020你还不会Java8新特性?方法引用详解及Stream 流介绍和操作方式详解(三)

    方法引用详解 方法引用: method reference 方法引用实际上是Lambda表达式的一种语法糖 我们可以将方法引用看作是一个「函数指针」,function pointer 方法引用共分为4 ...

  9. Underscore _.template 方法使用详解

    为什么用「void 0」代替「undefined」 undefined 并不是保留词(reserved word),它只是全局对象的一个属性,在低版本 IE 中能被重写. 事实上,undefined ...

随机推荐

  1. Koa微信公众号开发

    微信开发者模式开启需要服务器域名合法并且把接口配置好,这个接口是接通的关键,接通后微信后台的菜单设置功能,客服功能会失效,需要开发者自定义菜单和智能客服界面,并且接通后可以调用微信网页内部的定位分享等 ...

  2. H5易企秀

    周末被领导叫回来加班,说要做一个易企秀一样的页面,然后就有这篇笔记 原计划用几百个计时器去执行,后面放弃了,太难改了,还是选择了animate.css插件,这是一个纯css的插件,只需要引入css就行 ...

  3. 04.Delphi通过接口IInterface实现多重继承

    IInterface表示申明了一些函数,自己本身没有实现部分,需要由继承它的类来实现函数 uSayHello代码如下 unit uSayHello; interface uses SysUtils, ...

  4. U盘启动盘空间变小

    Windows下管理员身份运行cmd,调用diskpart,约5秒进入程序 磁盘管理中新建卷. 建议使用Rufus制作U盘启动盘.

  5. leetcode1019 Next Greater Node In Linked List

    """ We are given a linked list with head as the first node. Let's number the nodes in ...

  6. python进阶 廖雪峰(慕课网)

    1.函数式编程 变量名可以指向函数,那么函数就可以通过一个变量传递给另一个函数或者变量. map()函数:接收一个函数 f 和一个 list,并通过把函数 f 依次作用在 list 的每个元素上,得到 ...

  7. Win7安装Oracle Instantclient ODBC驱动 后配置DSN时出错的解决办法 SQORAS32

    安装过程简述 oracle官网下载了 instantclient-odbc-nt--.zip instantclient-basic-nt-.zip 我这是32位版的win7,按照需要下载对应的版本. ...

  8. 史上最全的mysql聚合函数总结(与分组一起使用)

    1.首先我们需要了解下什么是聚合函数 聚合函数aggregation function又称为组函数. 认情况下 聚合函数会对当前所在表当做一个组进行统计. 2.聚合函数的特点 1.每个组函数接收一个参 ...

  9. netty权威指南学习笔记一——NIO入门(2)伪异步IO

    在上一节我们介绍了四种IO相关编程的各个特点,并通过代码进行复习了传统的网络编程代码,伪异步主要是引用了线程池,对BIO中服务端进行了相应的改造优化,线程池的引入,使得我们在应对大量客户端请求的时候不 ...

  10. TP框架数据模型

    1.TP框架的数据模型需要建在Model文件夹下: 1.数据模型 与控制器相似,但是每个数据模型控制一张数据表. 2.数据模型可写可不写,如果不写 则沿用父类数据模型. 2.访问数据库: 1.更改数据 ...