django模型系统(二)

常用查询

  • 每一个django模型类,都有一个默认的管理器,objects

QuerySet表示数据库中对象的列表。他可以有0到国歌过滤器。过滤器通过给定参数,缩小查询范围(filter)。

QuerySet等同与select语句,过滤器等同于一个限制字句,比如where、limit

  • 使用.query可查看对应的SQL语句
  1. all()获取所有

    name.objects.all()queryset
  2. 获取第一条

    name.objects.first()返回的是对象
  3. 获取最后一条

    name.objects.last()返回的是对象
  4. get(**kwargs)根据给定的条件获取一个对象,如果符合多个或者没有就会报错
  5. filter(**kwargs)过滤,根据参数提供的条件,获取一个过滤器后的QuerySet,多个条件等同于select子句使用and连接,关键字参数的形参必须是模型中的字段名。
Student.objects.filter(name='xinlan').filter(age=18)
  1. exclude(**kwargs), 用法和filter一样,作用相反,它是排除
  2. order_by(*fields),根据给定的字段排序。多个的时候有先后顺序。
Student.objects.order_by('-age', 'name').query)
# 默认asc,-age 代表反向排序
  1. 切片 使用列表的切片语法操作query,除了不能用负索引,其他的都可以,它等价于LIMIT与OFFSET子句。[::]
  2. values(*fields)返回queryset, 这个queryset返回的是一个字典列表。参数fields指定了select中我们想要限制查询的字段。返回的字典列表中,只会包含我们指定的字段。如果不指定,包含所有字段。
  3. only(*fields)返回一个queryset,跟values一样,区别在于这个queryset是对象列表,only一定包含主键。
  4. defer(*fields) 用法与only相反
  5. 多条件OR连接,需要实现OR条件,我们要使用Q对象。
    • 注意:要导入模块from django.db.models import 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 精确匹配

    例如:Student.objects.filter(name__exact='XXX')#_exact可以不写
  • iexact 忽略大小写
  • contains 包含,对应sql的%
  • icontains 包含(忽略大小写)
  • in 等价sql的in
  • gt 大于:grate than
  • gte 大于等于:grate than equ
  • lt 小于:less than
  • lte 小于等于:less than equ
  • startswith 以什么什么开始
  • istartswith 忽略大小写
  • endwith 以什么什么结束
  • iendwith 忽略大小写
  • range **__range=(),范围区间,等价于sql:between...and...
  • isnull 是否为空

语法都是field__conditon= 是 两个下划线

count() ,统计。返回queryset的长度

聚合函数

语法:

list_name.objects.aggregate(anyname=Avg('age'))
#必须要用aggregate方法,anyname自己命名
#返回的市dit字典,不是query语句,无法查询sql语句
  • Avg 平均值
# 计算同学们的年龄平均值
res = Student.objects.aggregate(age_avg=Avg('age'))
  • Max 最大值
    # 找到最大的年龄
res = Student.objects.aggregate(age_max=Max('age'))
  • Min 最小值
  • Sum求和
  • 分组,聚合,分组需要结合values,annotate和聚合方法看下面的案例
  # 查询男生女生分别有多少人
In [84]: from django.db.models import Count
#必须要导入模块
In [85]: res = Student.objects.values('sex').annotate(Count('sex'))

常用模型字段类型

官方文档说明:

https://docs.djangoproject.com/en/2.1/ref/models/fields/#field-types

表关系实现

django 中,模型通过特殊的字段进行关系连接

  • 一对一
  • 一对多
  • 多对多

例如:

anyname = models.OneToOneField('class_name',on_delete=models.CASCADE)#on_delete级联等外键关系

注意事项:

  • 多对多关系,如果第三方表还有额外得到属性,需要手动创建第三方表并加入额外属性。并且要使用through属性指定第三张表。

    例如:

    class A(models.Model):
    pass class B(models.Model):
    anyname = models.ManyToManyField('A',through='C')
    #B和A表多对多关联,手动生成第三方表,通过through指定第三方表C,在表C中可以添加额外属性 class C(models,Model):
    pass

django模型系统(二)的更多相关文章

  1. django模型系统二

    常用查询及表关系的实现 1.常用查询 每一个django模型类,都有一个默认的管理器 objects QuerySet表示数据库中对象的列表,它可以有0到多个过滤器.过滤器通过给定参数,缩小查询范围. ...

  2. python的Web框架,Django模型系统二,模型属性,及数据库进阶查询

    原始数据接上篇文章来操作.可能需要查看后才能懂.点击这里查看 1.常用的模型字段类型 官方文档:https://docs.djangoproject.com/en/2.1/ref/models/fie ...

  3. django模型系统(一)

    django模型系统(一) djangode ORM ORM:对像关系映射 用python概念去表达数据库 数据库配置(mysql) 安装pumysql 修改项目目录下的__init__.py imp ...

  4. {django模型层(二)多表操作}一 创建模型 二 添加表记录 三 基于对象的跨表查询 四 基于双下划线的跨表查询 五 聚合查询、分组查询、F查询和Q查询

    Django基础五之django模型层(二)多表操作 本节目录 一 创建模型 二 添加表记录 三 基于对象的跨表查询 四 基于双下划线的跨表查询 五 聚合查询.分组查询.F查询和Q查询 六 xxx 七 ...

  5. day 70 Django基础五之django模型层(二)多表操作

    Django基础五之django模型层(二)多表操作   本节目录 一 创建模型 二 添加表记录 三 基于对象的跨表查询 四 基于双下划线的跨表查询 五 聚合查询.分组查询.F查询和Q查询 六 ORM ...

  6. day 56 Django基础五之django模型层(二)多表操作

    Django基础五之django模型层(二)多表操作   本节目录 一 创建模型 二 添加表记录 三 基于对象的跨表查询 四 基于双下划线的跨表查询 五 聚合查询.分组查询.F查询和Q查询 六 ORM ...

  7. 八.django模型系统(二)之常用查询及表关系的实现

    Ⅰ.常用查询  1.几个概念 每一个django模型类,都有一个默认的管理器,objects,查询就是依赖于objects管理器进行的(在创建时就被添加了). QuerySet表示数据库中对象的列表( ...

  8. django模型——数据库(二)

    模型--数据库(二) 实验简介 模型的一些基本操作,save方法用于把对象写入到数据库,objects是模型的管理器,可以使用它的delete.filter.all.order_by和update等函 ...

  9. Django模型系统——ORM校园管理系统代码

    1.models.py from django.db import models # Create your models here. class Class(models.Model): id = ...

随机推荐

  1. cookie,localStorage和sessionStorage的区别

    cookie已经很久没有用过了,一直觉得session Storage和local Storage更加好用一些.

  2. Wireshark使用介绍(二):应用Wireshark观察基本网络协议

    TCP: TCP/IP通过三次握手建立一个连接.这一过程中的三种报文是:SYN,SYN/ACK,ACK. 第一步是找到PC发送到网络服务器的第一个SYN报文,这标识了TCP三次握手的开始. 如果你找不 ...

  3. Angular4 组件生命周期

  4. UDP广播 与 TCP客户端 --服务端

    随着倒计时的响声,自觉无心工作,只想为祖国庆生. 最近有遇到过这样一个问题,将摄像头识别的行人,车辆实时显示在客户端中.有提供接口,会以Json的数据的形式将实时将识别的对象进行Post提交.所以我们 ...

  5. arcgis for js 之 获取两点之间的距离

    换了新公司,接触新行业,半路出家,看着别人的代码,看着api慢慢理解. 需求如下:已知两点坐标求距离. 思路,没有,站在同事的肩膀上踩路子,给的这个链接 https://developers.arcg ...

  6. Ubuntu下载

    由于官网服务器在国外,下载速度奇慢,所以我们可以利用阿里云镜像下载ubuntuubuntu 14.04:http://mirrors.aliyun.com/ubuntu-releases/14.04/ ...

  7. Redis做分布式锁

    在分布式系统中,在接口没有保证幂等性或者在某些场景下相同的服务需要有且仅有一个服务执行的情况下,需要使用分布式锁来保证系统的安全执行. 分布式锁的执行顺序,有服务A,分别部署了三个节点为A1.A2.A ...

  8. java面试经常问到的计算机网络问题

    GET 和 POST 的区别 GET请注意,查询字符串(名称/值对)是在 GET 请求的 URL 中发送的:/test/demo_form.asp?name1=value1&name2=val ...

  9. 用iPhone查看pc电脑上写的html(Mac电脑Charles)简单版

    对于客户端同学开发来说,写一段代码想在真机上看看,是非常容易的. 那么在这么一个大前端的环境下,客户端开发想写点html和js代码,又想在手机上看看效果,怎么办呢? 需要以下几个步骤: 大体流程:1. ...

  10. opencv学习之路(40)、人脸识别算法——EigenFace、FisherFace、LBPH

    一.人脸识别算法之特征脸方法(Eigenface) 1.原理介绍及数据收集 特征脸方法主要是基于PCA降维实现. 详细介绍和主要思想可以参考 http://blog.csdn.net/u0100066 ...