假定models中有一个类BookInfo

模块查询不同于sql语句,模块查询的结果会返回符合条件的整个一行的对象,或者多个对象组成的查询集。

查询集类似列表,有相似的方法。

1 model查询语句:

  1 get(条件) 查询一条   多条或者没有数据会抛出异常 返回一个BookInfo对象

BookInfo.objects.get(id = 1)    #查询bookinfo表中id为1的数据

  2 all() 查询所有 不能加条件 返回一个查询集 类似列表,有和列表一样的方法

BookInfo.objects.all()  #查询bookinfo表中所有的数据

  3 filter(条件) 查询符合条件的全部对象 返回一个查询集

BookInfo.objects.filter(isDelete = false)

  4 exclude(条件) 查询不符合条件的所有 返回一个查询集

2 查询条件:  模型类属性__条件 = 值 

  1 判断相等:    __exact   可以省略条件,直接 属性= 值

BookInfo.objects.filter(id__exact = 1)  #查询表中id是1的

  2 模糊查询 包含:  __contains

BookInfo.objects.filter( btitle__contains = "传" ) #查询表中  btitle字段包含 传 的

  3 开头 结尾:  __startswith   __endwith

BookInfo.objects.filter( btitle__endswith="")  #查询btitle 以 "" 为结尾的
BookInfo.objects.filter( btitle__startswidth = "")

  4 空查询: __isnull    __isnotnull = True/False

BookInfo.objects.filter( btitle__isnull = False )

  5 查询范围  __in = 元组/列表

BookInfo.objects.filter( bid__in = [1,3,5] )

  6 比较大小 __gt大于   __gte大于等于    __lt小于    __lte小于等于

BookInfo.objects.filter( id__gt = 3 )  # id大于3

  7 查询日期  __year  __mont __day  __weekday  __hour  __second

BookInfo.objects.filter(bpub_date__year = 1980) # 查询1980年
BookInfo.objects.filter( bpub_date__gt = date(1980,1,1) ) #大于指定日期

3 多个属性的比较: 引入F对象

#例:查询阅读量大于等于评论量的图书。

from django.db.models import F

list = BookInfo.books.filter(bread__gte=F('bcommet'))

4 逻辑 与 或 非

#例:查询阅读量大于20,并且编号小于3的图书。

list=BookInfo.books.filter(bread__gt=20,id__lt=3)
#或者
list=BookInfo.books.filter(bread__gt=20).filter(id__lt=3)

Q对象可以使用 &表示逻辑与,|表示逻辑或,~表示非not。

from django.db.models import Q
#例:查询阅读量大于20,或编号小于3的图书,只能使用Q对象实现

list = BookInfo.books.filter(Q(bread__gt=20) | Q(pk__lt=3))
#例:查询编号不等于3的图书。

list = BookInfo.books.filter(~Q(pk=3))

5 聚合函数:

使用aggregate()过滤器调用聚合函数。

聚合函数定义在django.db.models中  Avg,Count,Max,Min,Sum

from django.db.models import Sum
#例:查询图书的总阅读量。
list = BookInfo.books.aggregate(Sum('bread'))
#例:查询图书总数。
list = BookInfo.books.count()

  

django的models模块查询方法的更多相关文章

  1. Django开发之路 二(django的models表查询)

    django的models表查询 一.单表查询 (1) all(): 查询所有结果 # 返回的QuerySet类型 (2) filter(**kwargs): 它包含了与所给筛选条件相匹配的对象 #返 ...

  2. django学习~models之查询

    一 简介:今天学习models查询的一些东西 二 理解概念 Queryset 定义 从数据库中查询出来的结果一般是一个集合,这个集合叫做 QuerySet 三 细节学习 一 常用的models函数 . ...

  3. django之models模块使用

    定义模型 将数据库表定义成类,集成models.Model from django.db import models # Create your models here. class Author(m ...

  4. django学习-15.ORM查询方法汇总

    1.前言 django的ORM框架提供的查询数据库表数据的方法很多,不同的方法返回的结果也不太一样,不同方法都有各自对应的使用场景. 主要常用的查询方法个数是13个,按照特点分为这4类: 方法返回值是 ...

  5. Django之models模块

    一.字段 1. AutoField(Field) int自增列,必须填入参数 primary_key=True 2.BigAutoField(AutoField) bigint自增列,必须填入参数 p ...

  6. 第三百零八节,Django框架,models.py模块,数据库操作——链表结构,一对多、一对一、多对多

    第三百零八节,Django框架,models.py模块,数据库操作——链表结构,一对多.一对一.多对多 链表操作 链表,就是一张表的外键字段,连接另外一张表的主键字段 一对多 models.Forei ...

  7. 第三百零七节,Django框架,models.py模块,数据库操作——表类容的增删改查

    Django框架,models.py模块,数据库操作——表类容的增删改查 增加数据 create()方法,增加数据 save()方法,写入数据 第一种方式 表类名称(字段=值) 需要save()方法, ...

  8. 第三百零六节,Django框架,models.py模块,数据库操作——创建表、数据类型、索引、admin后台,补充Django目录说明以及全局配置文件配置

    Django框架,models.py模块,数据库操作——创建表.数据类型.索引.admin后台,补充Django目录说明以及全局配置文件配置 数据库配置 django默认支持sqlite,mysql, ...

  9. 五 Django框架,models.py模块,数据库操作——表类容的增删改查

    Django框架,models.py模块,数据库操作——表类容的增删改查 增加数据 create()方法,增加数据 save()方法,写入数据 第一种方式 表类名称(字段=值) 需要save()方法, ...

随机推荐

  1. 关于Android sdkmanager目录结构的总结

    SDK Platform是指一些已经编写好的库函数,类文件,我们可以直接调用 Samples for SDK是指一些样本代码,可以导入eclipse运行出来查看里面函数的效果 以system imag ...

  2. 【Unity3D与23种设计模式】建造者模式(Builder)

    GoF中定义: "将一个复杂的构建流程与它的对象表现分离出来,让相同的构建流程可以产生不同的对象行为表现." 建造者模式可以分为两个步骤来实施: 1.将复杂的构建流程独立出来,并将 ...

  3. USB协议基础知识笔记

    usb协议 功能层: 控制传输.中断传输.块传输(批量传输).同步传输 设备层:管理USB设备.分配地址.读取设备描述符 总线接口层:采用NRZI编码-反向非归零编码(0将前一个电平翻转,1不翻转) ...

  4. CSS Grid 网格布局全解析

    介绍 CSS Grid(网格) 布局使我们能够比以往任何时候都可以更灵活构建和控制自定义网格. Grid(网格) 布局使我们能够将网页分成具有简单属性的行和列.它还能使我们在不改变任何HTML的情况下 ...

  5. c++趣味之shared_ptr额外好处

    shared_ptr(sp)额外好处是什么?即使被转为基类,析构函数也可以正常执行. 已知两个类 class foo{}; class bar:foo{public:~bar(){}}; 先来看不用s ...

  6. MYSQL数据库学习十三 使用MySQL常用函数

    13.1 字符串函数 对于针对字符串位置的操作,第一个位置被标记为1. 函数 功能 CONCAT(str1,str2...strn) 连接字符串str1.str2....strn INSERT(str ...

  7. MySQL 中添加列、修改列以及删除列

    ALTER TABLE:添加,修改,删除表的列,约束等表的定义. 查看列:desc 表名; 修改表名:alter table t_book rename to bbb; 添加列:); 删除列:alte ...

  8. 兄弟连学Python-3Python变量和数据类型

    变量:变量就是可以改变的量.如:x+y = 10 x=5 , y=? x=7 , y=? 这是数学里的变量 通俗的理解:变量     =   生活中的容器(盒子) 变量的赋值操作  =  我们把物品放 ...

  9. 关于c++停止工作

    出现这样情况有两种原因 : 1未初始化 2用scanf未用符号& 3当0做分母时

  10. Django SNS 微博项目开发

    1.功能需求 一个人可以follow很多人 一个用户如果发了新weibo会自动推送所有关注他的人 可以搜索.关注其它用户 可以分类关注 用户可以发weibo, 转发.收藏.@其它人 发微博时可选择公开 ...