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. AJax提交表单数据到后台springmvc接收

    第一种方法直接用serialize()方法 function insert(){ $.ajax({ type:"POST", url:"${pageContext.req ...

  2. Nginx做流媒体服务Windows版实现直播

    声明:网上有很多关于Linux系统的配置,这里就不记录了.刚开始搭建直播室,用的是Java语言, Java开源的流媒体服务有Red5,但是很久没更新了,而且文档较少不容易上手,对于直播功能相对要求较低 ...

  3. tpot ufunc 'isnan' not supported for the input types, and the inputs could not be safely coerced to any supported types according to the casting rule ''safe''

    机器学习训练的时候报出这个问题 是因为dataframe中的数据类型有一个是‘object’,把它转成int,或float 就行,如下 df['A'] = df['A‘].astype(int) 参考 ...

  4. Java作业:第二次过程性考核 ——长春职业技术学院 16级网络工程

    ## 时间有限,脑力不足 ## 只给出代码部分(附带注释) 码云 https://gitee.com/SoridoD/codes 7-5: import java.util.Scanner; clas ...

  5. Win7下“回收站已损坏,是否清空该驱动器上的回收站”解决方法

    最近买的移动硬盘,总是不能进行安全删除,有事还会提示“回收站已损坏,是否清空该驱动器上的回收站”,可以通过下面的命令进行解决: 开始–>运行–>cmd 点确定 在cmd窗口输入rd /s ...

  6. jar 包启动脚本

    #!/bin/bash JAVA_HOME=/usr/java/default #java虚拟机启动参数 JAVA_OPTS="-server -Xms800m -Xmx800m -Xmn2 ...

  7. json格式字符串用Uncaught SyntaxError: Unexpected token ' Uncaught SyntaxError: Unexpected number

    Unexpected number(index)的错误用的json字符串如 var jsonStr = "{1:'北京note备注信息',2:'上海note备注信息',3:'广东note备注 ...

  8. effective java——32用EnumSet代替位域

    什么是位域?为什么用到它?先来看一个例子: public class Test { public static final byte STYLE_BOLD = 1<<0; // 1 pub ...

  9. Mac上配置maven+eclipse+spark开发环境

    1.安装jdk 2.下载scala-ide.官网:http://scala-ide.org 3.安装maven 4.在eclipse中,配置maven的安装了路径.偏好设置--->maven-- ...

  10. Intellij IDEA 导入Maven项目

    本人一直使用的eclipse, 但都说IDEA 是java界中最好使用的编辑器 ,所以开始了IDEA的学习,最近使用到了 IDEA 但是,既然编辑器有所差别,所以在使用过程中也难免遇到一些费劲的事情. ...