django模型系统二
常用查询及表关系的实现
1.常用查询
每一个django模型类,都有一个默认的管理器 objects
QuerySet表示数据库中对象的列表,它可以有0到多个过滤器。过滤器通过给定参数,缩小查询范围。
QuerySet等同于select语句,过滤器是一个限制子句,比如where,limit。
all() 获取所有
Student.objects.all() #返回的是queryset
获取第一条
Student.objects.first() #返回的是对象
获取最后一条
Student.objects.last() #返回的是对象
get(**kwargs)根据给定的条件获取一个对象,如果符合多个或没有就会报错
filter(**kwargs)过滤,根据参数提供的条件,获取一个过滤器后的QuerySet,多个条件等同于select子句使用and连接,关键字的参数的形参必须是模型中的字段名。
Student.objects.filter(name='张三').filter(sex=0)
exclude(**kwargs)用法和filter一样,作用相反,它是排除
order(*fileds),根据给定的字段排序
res.order_by('-age','name') #默认asc, -age代表反向排序
切片:使用列表的切片语法操作query,除了不能用负索引,其他都可以,他等价于LIMIT与OFFSET子句
values(*fileds)返回queryset,这个queryset返回的是一个字典列表,参数fields指定了select中我们想要限制查询的字段。返回的字典列表中,只会包含我们指定的字段。如果不指定,包含所有字段。
res=Student.objects.values('name')
only(*fileds)返回一个queryset,跟values一样,区别在于这个queryset是对象列表,only一定包含主键。
res=Student.objects.only('name')
defer(*fields)用法与only相反
res=Student.objects.defer('sex')
多条件OR连接,需要实现OR条件,我们要使用Q对象
from django.db.models import Q
res=Student.objects.filter(Q(age=18)|Q(age=19)).only('name')
等价于下面的sql:
SELECT `teacher_student`.`id`, `teacher_student`.`name` FROM `teacher_student` WHERE
(`teacher_student`.`age` = 18 OR `teacher_student`.`age` = 19)
查询条件:
exact 精确匹配
res=Student.objects.filter(name__exact='张三')
iexact 忽略大小写
res=Student.objects.filter(name__iexact='张三')
contains
res=Student.objects.filter(name__contains='张三')
icontains
in
res=Student.objects.filter(name__in=[18,20])
gt (great than)
gte (great than equal)
res=Student.objects.filter(name__gte=18)
lt (less than)
res=Student.objects.filter(name__lt=18)
lte
startswith 以什么开始
res=Student.objects.filter(name__startswith='张')
istartswith
endwith 以什么结尾
iendwith
range 范围区间
res=Student.objects.filter(name__range=(18,20))
isnull
res=Student.objects.filter(name__isnull=True)
语法都是field__condition 是两个下划线
count返回queryset的长度
聚合函数
Avg
#计算同学们的年龄平均值
res=Student.objects.aggregate(age_avg=Avg('age'))
Max最大值
#找到年龄最大的学生
res=Student.objects.aggregate(age_max=Max('age'))
Min最小值
sum求和
分组,聚合,分组需要结合values,annotate和聚合方法看下面的案例
#查询男生女生分别有多少人
from django.db.models import Count res=Student.objects.values('sex').annotate(Count('sex'))
2.常用模型字段类型
参考官方文档
https://docs.djangoproject.com/en/2.1/ref/models/fields/#field-types
3.表关系实现
django中,模型通过特殊的字段进行关系连接。
一对一
一对多
多对多
django模型系统二的更多相关文章
- python的Web框架,Django模型系统二,模型属性,及数据库进阶查询
原始数据接上篇文章来操作.可能需要查看后才能懂.点击这里查看 1.常用的模型字段类型 官方文档:https://docs.djangoproject.com/en/2.1/ref/models/fie ...
- django模型系统(二)
django模型系统(二) 常用查询 每一个django模型类,都有一个默认的管理器,objects QuerySet表示数据库中对象的列表.他可以有0到国歌过滤器.过滤器通过给定参数,缩小查询范围( ...
- django模型系统(一)
django模型系统(一) djangode ORM ORM:对像关系映射 用python概念去表达数据库 数据库配置(mysql) 安装pumysql 修改项目目录下的__init__.py imp ...
- {django模型层(二)多表操作}一 创建模型 二 添加表记录 三 基于对象的跨表查询 四 基于双下划线的跨表查询 五 聚合查询、分组查询、F查询和Q查询
Django基础五之django模型层(二)多表操作 本节目录 一 创建模型 二 添加表记录 三 基于对象的跨表查询 四 基于双下划线的跨表查询 五 聚合查询.分组查询.F查询和Q查询 六 xxx 七 ...
- day 70 Django基础五之django模型层(二)多表操作
Django基础五之django模型层(二)多表操作 本节目录 一 创建模型 二 添加表记录 三 基于对象的跨表查询 四 基于双下划线的跨表查询 五 聚合查询.分组查询.F查询和Q查询 六 ORM ...
- day 56 Django基础五之django模型层(二)多表操作
Django基础五之django模型层(二)多表操作 本节目录 一 创建模型 二 添加表记录 三 基于对象的跨表查询 四 基于双下划线的跨表查询 五 聚合查询.分组查询.F查询和Q查询 六 ORM ...
- 八.django模型系统(二)之常用查询及表关系的实现
Ⅰ.常用查询 1.几个概念 每一个django模型类,都有一个默认的管理器,objects,查询就是依赖于objects管理器进行的(在创建时就被添加了). QuerySet表示数据库中对象的列表( ...
- django模型——数据库(二)
模型--数据库(二) 实验简介 模型的一些基本操作,save方法用于把对象写入到数据库,objects是模型的管理器,可以使用它的delete.filter.all.order_by和update等函 ...
- Django模型系统——ORM校园管理系统代码
1.models.py from django.db import models # Create your models here. class Class(models.Model): id = ...
随机推荐
- 紫书 例题 10-21 UVa 11971(连续概率)
感觉这道题的转换真的是神来之笔 把木条转换成圆,只是切得次数变多一次 然后只要有一根木条长度为直径就租不成 其他点的概率为1/2^k 当前这个点的有k+1种可能 所以答案为1 - (k+1)/2^k ...
- 二叉树、B树、B+树、B*树、LSM树
HBase 对于数据产品,底层存储架构直接决定了数据库的特性和使用场景.RDBMS(关系型数据库)使用 B树 及 B+树 作为数据存储结构. HBase 使用 LSM树. . 二叉树 ...
- 隐马尔科夫模型(HMM)
基本概念 1Markov Models 2Hidden Markov Models 3概率计算算法前向后向算法 1-3-1直接计算 1-3-2前向算法 1-3-3后向算法 4学习问题Baum-Welc ...
- Hadoop HDFS (4) Hadoop Archives
用HDFS存储小文件是不经济的,由于每一个文件都存在一个block里,每一个block的metadata又在namenode的内存里存着,所以,大量的小文件.会吃掉大量的namenode的内存.(注意 ...
- Android LruCache 压缩图片 有效避免程序OOM
转载请注明出处:http://blog.csdn.net/guolin_blog/article/details/9316683 本篇文章主要内容来自于Android Doc,我翻译之后又做了些加工, ...
- codeforces 710C Magic Odd Square(构造或者n阶幻方)
Find an n × n matrix with different numbers from 1 to n2, so the sum in each row, column and both ma ...
- Assembly.Load 详解(c#)
我们在使用C# 语言的Assembly.Load 来加载托管程序集并使用反射功能时,一般需要先通过Assembly.Load(), Assembly.LoadFrom() 等方法将目标托管程序集加载到 ...
- [Chromium文档转载,第001章] Mojo Migration Guide
For Developers > Design Documents > Mojo > Mojo Migration Guide 目录 1 Summary 2 H ...
- Fedora27 源配置
一.添加阿里源,阿里源我感觉是现在国内比较好用的源,支持的发行版比较全.配置方法1.备份系统自带的源mv /etc/yum.repos.d/fedora.repo /etc/yum.repos.d/f ...
- Cisco交换机IOS配置介绍
一.模式• 用户模式(>):• 特权模式(#):• 全局配置模式(config#):• 接口配置模式(config-if#):• 线路模式(#config-line): 二.基本IOS命令结构• ...