django的models模块查询方法
假定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模块查询方法的更多相关文章
- Django开发之路 二(django的models表查询)
django的models表查询 一.单表查询 (1) all(): 查询所有结果 # 返回的QuerySet类型 (2) filter(**kwargs): 它包含了与所给筛选条件相匹配的对象 #返 ...
- django学习~models之查询
一 简介:今天学习models查询的一些东西 二 理解概念 Queryset 定义 从数据库中查询出来的结果一般是一个集合,这个集合叫做 QuerySet 三 细节学习 一 常用的models函数 . ...
- django之models模块使用
定义模型 将数据库表定义成类,集成models.Model from django.db import models # Create your models here. class Author(m ...
- django学习-15.ORM查询方法汇总
1.前言 django的ORM框架提供的查询数据库表数据的方法很多,不同的方法返回的结果也不太一样,不同方法都有各自对应的使用场景. 主要常用的查询方法个数是13个,按照特点分为这4类: 方法返回值是 ...
- Django之models模块
一.字段 1. AutoField(Field) int自增列,必须填入参数 primary_key=True 2.BigAutoField(AutoField) bigint自增列,必须填入参数 p ...
- 第三百零八节,Django框架,models.py模块,数据库操作——链表结构,一对多、一对一、多对多
第三百零八节,Django框架,models.py模块,数据库操作——链表结构,一对多.一对一.多对多 链表操作 链表,就是一张表的外键字段,连接另外一张表的主键字段 一对多 models.Forei ...
- 第三百零七节,Django框架,models.py模块,数据库操作——表类容的增删改查
Django框架,models.py模块,数据库操作——表类容的增删改查 增加数据 create()方法,增加数据 save()方法,写入数据 第一种方式 表类名称(字段=值) 需要save()方法, ...
- 第三百零六节,Django框架,models.py模块,数据库操作——创建表、数据类型、索引、admin后台,补充Django目录说明以及全局配置文件配置
Django框架,models.py模块,数据库操作——创建表.数据类型.索引.admin后台,补充Django目录说明以及全局配置文件配置 数据库配置 django默认支持sqlite,mysql, ...
- 五 Django框架,models.py模块,数据库操作——表类容的增删改查
Django框架,models.py模块,数据库操作——表类容的增删改查 增加数据 create()方法,增加数据 save()方法,写入数据 第一种方式 表类名称(字段=值) 需要save()方法, ...
随机推荐
- Spring源码学习:第1步--在Spring源码中添加最简单的Demo代码
为了最大程度地贴近Spring源码并进行学习,一种比较直接的做法是:直接在Spring源码中加入Demo代码,并进行调试. 参照以前使用Spring的经验,Spring最简单的使用方法是:一个实体类. ...
- parted分区和挂载及非交互式操作
author : headsen chen date : 2017-11-17 09:45:36 个人原创,转载请注明作者,出处,否则依法追究法律责任 1,将磁盘上原有的分区删除掉: 进入:#pa ...
- python3.X中的循环
获取数字范围: range() 在python3.x中使用range(): >>> list(range(7)) [0, 1, 2, 3, 4, 5, 6] >>> ...
- Dynamics 365 Online-使用Azure Logic App 与 Dynamics 365 集成
什么是Logic App? Azure Logic App 是微软发布的集成平台的产品,有助于生成,计划和自动完成工作流形式的流程,适合跨企业或组织集成,数据,系统和服务.与此同时,Logic App ...
- [poj3687]Labeling Balls_拓扑排序
Labeling Balls poj-3687 题目大意:给出一些球之间的大小关系,求在满足这样的关系下,编号小的尽量比编号大的球的方案. 注释:1<=N(球的个数)<=200,1< ...
- SQL中的DML、DDL以及DCL
DML(data manipulation language)是数据操纵语言:它们是SELECT.UPDATE.INSERT.DELETE,就象它的名字一样,这4条命令是用来对数据库里的数据进行操作的 ...
- ibatis.net 入门demo 实现基本增删改查
1.项目架构体系 DAO(数据访问层) Domain(实体层) Text(表示层) 2.比较重要的是需要添加两个dll的引用,以及两个配置文件和一个XML文件 两个 IbatisNet.Com ...
- iPhone的App嵌入html页面问题
测试环境:iPhone ios 11.0.3 问题:iPhone App嵌入HTML页面,页面拉动到底部时,手势从屏幕底部边缘开始往上拉动,页面出现白色图层,且html页面一屏外的会卡住,无法滚动,需 ...
- C语言第六周博客作业--数据类型
一.PTA实验作业 题目1: 7-6 掉入陷阱的数字 1. 本题PTA提交列表 2.设计思路 定义变量N,i,g=1表示位数,a表示各位数字相加的和,b=0,j,N1,c,d用于储存N do{ for ...
- alpha冲刺总结随笔
前言:前面乱乱糟糟整了一路,到最后终于可以稳定下来了.安安心心做个总结,然后把之后要做的事情都理清楚好了. 新学长似乎是个正经[并不]大腿. 看起来也不用都是一个人或者跟陈华学长两个人对半开了[突然摸 ...