django模型二


  • 常用模型字段类型

    • IntegerField   →    int
    • CharField   →   varchar
    • TextField  →    longtext
    • DateField  →   date
    • DateTimeField   →   datetime
    • AutoField  →    int  (自增长)

 

  • Field的常用参数

    • primary_key:是否设置为主键
    • unique:是否唯一
    • null:指定是否为空,默认是False
    • blank:等于True时form表单验证时可以为空,默认False
    • default:设置默认值
    • DateField.auto_now:每次修改都会将当前时间更新进去,只有调用:QuerySet.update方法将不会调用,这个参数只是Date和DateTime以及TimModel.save()方法会调用类的时候才有的
    • DateField.auto_now_add:第一次添加进去,都会将当前时间设置进去。以后修改,不会修改这个值
  • 常用查询

    • 通过模型类上的管理器(模型类.objects)来构造QuerySet(数据库中对象的集合:select语句)
    • all() :获取所有记录  返回的是queryset,支持切片
    • first() :获取的是第一条记录,返回的是对象
    • last():获取最后一条,返回的是对象
    • get(**kwargs):根据给定的条件,获取一个对象,如果有多个对象符合,则会报错
    • fillter(**kwargs):根据给定的条件,获取一个过滤后的queryset
    • exclude(**kwargs):和fillter的作用相反
    • 多条件的QR连接,用到Q对象 (django.db.models.Q)
      • from django.db.models import Q
      • 模型类.objects.fillter(Q(age=0)|Q(age=1))
    • values(*filed):返回一个queryset,返回一个字典列表,而不是数据对象only(*filed):返回queryset,对象列表,注意only返回一定包含主键字段
      • 模型类.objects.values(字段变量名)
      • 可通过列表取值的方法直接取出value
    • defer(*field):用法和only一样,作用和only相反
    • onder_by:根据给定的字段排序,默认从小到大;倒序只需在所要查询的字段的前面加上一个减号就好了
    • 切片:和Python的列表切片用法相似,不支持负索引,数量大时不用步长
      • 切片之后,不在支持附加过滤条件与排序

      

  • 常用聚合条件查询

    • exact       //支持 get   fillter     exclude

      • 准确匹配

        • 模型类.objects.get(id__exact=0)

          • 查询该表里的id=0的信息
    • iexact
      • 不区分大小写的匹配(模糊匹配)
    • contains
      • 包含匹配,找到包含所传入的对象的值
    • icontains
      • 不区分大小写的包含匹配
    • in
      • 给定范围查询,返回查到的对象

        • 模型类.objects.get(id__in=[给定的范围])
    • range
      • 给定的范围查询,返回所有范围对象

        • 模型类.objects.get(id__range(给定的范围)
    • gt
      • 查询大于某一范围的对象并返回

        • 模型类.objects.get(id__gt=给定的值)
    • gte
      • 查询大于等于某一范围的值并返回

        • 模型类.objects.get(id__gte=给定的值)
    • lte
      • 查询小于等于某一范围的值并返回
    • lt
      • 查询小于某一范围的值并返回
    • startswith
      • 查询以某某开头的对象并返回
      • 大小写敏感
    • istartwith
      • 查询以某某开头的对象并返回
      • 大小写不敏感
    • endswith
    • iendswith
    • isnull

    

  • 聚合查询

    • from django.db.models import Avg, Max, Count, Sum
    • count   // 计数
      • 可跟不同的对象结合使用

        • 模型类.objects.get(id__gte=给定的值).count()
        • 模型类.objects.all().count()
    • avg  // 平均数
      • 模型类.objects.aggregate(age_avg=Avg('age'))

        • 查询年龄的平均数
    • max
      • 模型类.objects.aggregate(age_max=Max('age'))
    • min
    • sum
  • 分组查询
    • 模型类.objects.values('sex').annotate(Count('sex')

django模型二的更多相关文章

  1. django模型系统(二)

    django模型系统(二) 常用查询 每一个django模型类,都有一个默认的管理器,objects QuerySet表示数据库中对象的列表.他可以有0到国歌过滤器.过滤器通过给定参数,缩小查询范围( ...

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

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

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

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

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

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

  5. django Model模型二及Model模型对数据库的操作

    在django模型中负责与数据库交互的为Model层,Model层提供了一个基于orm的交互框架 一:创建一个最基本的Model from __future__ import unicode_lite ...

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

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

  7. django模型系统二

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

  8. django模型

    用django时,只要用到数据库就得用到模型. 一.数据库的MTV开发模式 从MVC到MTV 所谓软件架构的MVC模式将数据的存取逻辑(Module),表现逻辑(View)和业务逻辑(Controll ...

  9. 一 Django模型层简介(一)

    模型 django提供了一个强大的orm(关系映射模型)系统. 模型包含了你要在数据库中创建的字段信息及对数据表的一些操作 使用模型 定义好模型后,要告诉django使用这些模型,你要做的就是在配置文 ...

随机推荐

  1. Python-接口自动化(九)

    python操作Excel处理测试数据(九) (十)python操作Excel读/写测试数据 1.夹心饼干 setUp:在每一条测试用例执行之前执行 tearDown:在每一条测试用例执行之后执行 上 ...

  2. git常用命令学习笔记

    安装好git之后即可使用git来管理项目了,鼠标右键点击 git bash出现命令黑窗口,接下来执行git指令即可. https://git-scm.com/book/zh/v2 以下整理了git常用 ...

  3. javeEE第一周

    1.我对javaEE这一门课的要求和想要达到的一个效果: 我对javaEE还是比较感兴趣的,大家也知道我是一个懂安全的PHPER,也有一些项目经验,我发现PHP做的web开发试用的场合主要是一些中小型 ...

  4. linux使用npm成功安装命令后,执行时却报找不到命令的问题

    # 使用npm安装serve命令 ~$ npm install serve --global 安装成功 # 可是执行命令会报错 ~$ serve -v bash: serve: command not ...

  5. js jquery 正则去空字符

    1.正则去空字符串: var str1=" a b c "; var strtrim=str1.replace(/\s/g,""); 2.js去前后空字符串: ...

  6. MySql主从搭建详细步骤

    环境: linux64位,一台机器两个实例,主库3306端口,从库3307端口 步骤: 一.下载安装 先下载安装mysql,这里使用了5.7.21版本,具体过程不做详细说明,可自行查资料如何下载 二. ...

  7. *args和**kwargs的区别

    *args和**kwargs表示可变长度的参数. *args是元组类型: **kwargs是字典类型: 注意:arg.*args.**kwargs三个参数的位置必须是固定的,否则会报错.

  8. TCP聊天工具的实现

    由于本人天生愚钝,所以关于聊天工具的编程一直都没学会,尽管网上教程一大堆,但是关于IdTCPClient  IdTCPServer 的不多,今天终于学会一些,分享给像我一样纠结的小伙伴,下一步学习多线 ...

  9. IIS--------问题解决(localhost可以访问,本地ip不可以)

    api:localhost可以访问,本地ip就不可以,报错:405 解决方案:api项目 - 属性 - web - 服务器 将:iis-express 改为 本地iis 创建虚拟目录:eg:http: ...

  10. [ffmpeg]安装

    下载源码: 我们选择去官网http://ffmpeg.org下载.版本和打包方式譬如:ffmpeg-3.1.11.tar.bz2 安装过程: tar   -jxvf ./ffmpeg-3.1.11.t ...