django模型类数据库操作

数据库操作

添加数据

  • 1,创建类对象,属性赋值添加

    • book= BookInfo(name='jack',pub_date='2010-1-1')
      book.save()
    • book= BookInfo()
      book.name = 'java'
      book.pub_date = '2010-1-1'
      book.save()
  • 2,使用模型类的create方法
    • BookInfo.objects.create(name='jack',pub_date='2010-1-1')

      • 直接创建

        修改数据

  • 1,获取模型类对象,属性赋值修改
    • book = BookInfo.objects.get(name='jack')
      book.name='tom'
      book.pub_date='2010-1-1'
      book.save()

      • 因为修改的是模型类的属性
        获取对象的时候必须要使用get查询,获取类对象,
        使用filter会报没有name属性,因为filter结果是查询集
  • 2,使用模型类结果集的update()
    可以进行多个修改

    • BookInfo.objects.filter(name='tom').update(name='jack')

      • 直接修改,返回受影响的行数
        update是结果集的方法,使用filter查询

        删除数据

  • 1,获取对应模型类对象,调用delete方法删除
    • book=BookInfo.objects.get(name='jack').delete()

      • 返回删除的个数和对象
  • 2,使用模型类结果集的delete()
    可以进行多个删除

    • BookInfo.objects.filter(name='jack').delete()

      • 返回删除的个数和对象

        数据查询

        基本条件查询

  • 基本查询
    • get

      • 获取单个对象
    • all
      • 获取所有对象
    • count
      • 返回对象的个数
  • 过滤查询
    • filter

      • 根据条件获取对象,返回结果集
    • exclude
      • 根据条件获取不符合条件的对象的结果集

        • 语法:属性名字__比较运算符=值

          • 比较运算符有

            • exact相等

              • BookInfo.objects.filter(pk__exact=1)
              • BookInfo.objects.filter(pk=1)
            • contains包含
              • BookInfo.objects.filter(name__contains='p')
            • endswith/startswith开头/结尾
              • BookInfo.objects.filter(name__startswith='p')
            • isnull=True为空
              • BookInfo.objects.filter(name__isnull=True)
            • in=[]范围
              • BookInfo.objects.filter(id__in=[1,2,3])
            • gt大于
              lt小于
              gte大于等于
              lte小于等于

              • BookInfo.objects.filter(id__gt=4)
            • 日期查询
              year
              mouth
              day
              week
              day
              hour
              minute
              second

              • BookInfo.objects.filter(pub_date__year__gt=1980)
    • get
      • 获取单个对象,不是结果集,范围查询不能使用get

        F和Q对象

  • F对象
    • F('')引号
      原理是:直接执行原生sql语句获取值,可以满足两个属性之间的比较

      • BookInfo.objects.filter(readcount__gt=F('commentcount'))
      • BookInfo.objects.filter(readcount__gt=F('commentcount')*2)
  • Q对象
    • Q()
      多个过滤器逐个调用

      • &且

        • BookInfo.objects.filter(Q(id__gt=2)&Q(id__lt=5))
        • BookInfo.objects.filter(id__gt=2,id__lt=5)
      • |或
        • BookInfo.objects.filter(Q(id__gt=2)|Q(age__lt=55))
      • ~非
        • 子主题 1

          • BookInfo.objects.filter(~Q(id__gt=2))

            聚合函数和排序函数

  • 聚合函数
    • aggregate()过滤器调用聚合函数
      导入聚合函数:from django.db.models import Sum

      • Sum

        • BookInfo.objects.aggregate(Sum('readcount'))

          • 返回值:{‘read__count’:554}
          • Sum(' ')
      • Avg
      • Count
        • 可以直接使用

          • BookInfo.objects.count()
      • Max
      • Min
  • 排序函数
    • order_by(' ')对查询集进行排序
      返回的是一个还是一个查询集

      • BookInfo.objects.all().order_by('readcount')

        • BookInfo.objects.filter(id__gt=2).order_by('readcount')
      • 降序排序
        • BookInfo.objects.all().order_by('-readcount')

          查询集

  • filter
  • all
  • exclude
  • order_by

    关联查询

  • 一对多
    • 多的一方定义外键
    • 由一到多查询
      • 多对应的模型类名小写_set

        • BookInfo.objects.get(id=1).peopleinfo_set.all()
    • 由多到一查询
      • 外键

        • PeopleInfo.objects.get(id=1).book

          关联过滤查询

  • 一对多
    • 多模型为条件查一模型数据

      • BookInfo.objects.filter(peopleinfo__id=1)
    • 一模型作为条件查多模型数据
      • PeopleInfo.objects.filter(book__id=1)

        特点

        惰性执行

        缓存

        限制查询集,切片

  • BookInfo.objects.all()[0:2]

    exists()

  • 判断查询结果中是否有数据,True,False

XMind: ZEN - Trial Version

Django1.11模型类数据库操作的更多相关文章

  1. java工具类--数据库操作封装类

    java对数据库操作简单处理,如下代码即可,封装了 增删改查及获取连接.关闭连接. 代码如下: package com.test; import java.sql.Connection; import ...

  2. FunDA(11)- 数据库操作的并行运算:Parallel data processing

    FunDA最重要的设计目标之一就是能够实现数据库操作的并行运算.我们先重温一下fs2是如何实现并行运算的.我们用interleave.merge.either这几种方式来同时处理两个Stream里的元 ...

  3. Django-1.11中文文档——操作关联对象

    关联对象参考 写在最前面--基础示例模型如下: from django.db import models class Blog(models.Model): name = models.CharFie ...

  4. vs2017 + Python3.6 +Django1.11 连接mysql数据库

    不废话直接来. vs2017创建一个新的python web项目之后默认链接数据库是sqlite.但是我就想连接到Mysql 上面玩,于是开始倒腾了.下面是步骤 1.修改settings.py 文件需 ...

  5. python3.6+linux服务器+django1.11连接MYSQL数据库

    1.django创建一个项目,在项目的settings.py中配置Mysql DATABASES = { 'default': { 'ENGINE': 'django.db.backends.mysq ...

  6. PyCharm中 Django1.11配置Mysql数据库

    1.Django 中配置MySQL数据库 DATABASES = { 'default': { 'ENGINE': 'django.db.backends.mysql', 'NAME': '数据库名称 ...

  7. django的模型类管理器-----------数据库操作的封装

    模型实例方法 str():在将对象转换成字符串时会被调用. save():将模型对象保存到数据表中,ORM框架会转换成对应的insert或update语句. delete():将模型对象从数据表中删除 ...

  8. 多进程,多线程,使用sqlalchemy 创建引擎(单例模式),闭包装饰器承载数据库会话,装饰模型类的类方法

    python 多进程,多线程,使用 sqlalchemy 对数据库进行操作 创建引擎 & 获取数据库会话: 使用类的方式,然后在对象方法中去创建数据库引擎(使用单例,确保只创建一个对象,方法里 ...

  9. Django框架(七):模型(三) 关联、模型类的属性

    1. 关联 1.1 模型类关系 关系型数据库的关系包括三种类型: ForeignKey:一对多,将字段定义在多的一端中. ManyToManyField:多对多,将字段定义在任意一端中. OneToO ...

随机推荐

  1. BFPRT(中位数的中位数算法)

    BFPRT(中位数的中位数算法) 类似于快排,但是划分区间的策略不一样. 分组,组内排序: 取出每组的中位数组成一个数组,再取这个数组的中位数: 以取出的中位数作为partition的轴.

  2. Ubuntu18.04 LTS 搭建Cassandra集群

    环境需求 jdk8 root@node01:~# java -version java version "1.8.0_202" Java(TM) SE Runtime Enviro ...

  3. DevOps - 工程师职责

    章节 DevOps – 为什么 DevOps – 与传统方式区别 DevOps – 优势 DevOps – 不适用 DevOps – 生命周期 DevOps – 与敏捷方法区别 DevOps – 实施 ...

  4. 重装系统,新安装IDEA启动项目后,classnotfound:com.mysql.jdbc.Driver

    我最后解决是:这个Test connection会自动帮你下载的,但是如果中途一直叫你try again,甚至到后面点这个test connection有弹窗,但是单窗里面的选项你点击后没反应,我是直 ...

  5. 【pwnable.kr】cmd1

    最近的pwnable都是linux操作系统层面的. ssh cmd1@pwnable.kr -p2222 (pw:guest) 首先还是下载源代码: #include <stdio.h> ...

  6. 中文文本分类之TextRNN

    RNN模型由于具有短期记忆功能,因此天然就比较适合处理自然语言等序列问题,尤其是引入门控机制后,能够解决长期依赖问题,捕获输入样本之间的长距离联系.本文的模型是堆叠两层的LSTM和GRU模型,模型的结 ...

  7. poker2的配置使用

    1.映射Win键的诸多功能 切换输入法,shift+alt本身已经支持了,所以Win+Space就不管了 Win+Space映射为Fn+Space Win+E映射为Fn+E Win+R映射为Fn+R ...

  8. JSP编码规范

    JSP包含文件 <%@ include file=”relativeURI”%> //在翻译阶段执行加载,比如:校验是否登录通过 jsp的include指令元素读入指定页面的内容.并把这些 ...

  9. js加密(十四)mail.yw.gov.cn/ RSA

    1. url: http://mail.yw.gov.cn/ 2. target:登录js 3. 简单分析: 寻找加密js: 3.1 直接寻找加密的参数p是不好找的,所以我们试着去寻找一些更明显的参数 ...

  10. [NOIP2017] T4 跳房子 DP+二分

    Description 跳房子,也叫跳飞机,是一种世界性的儿童游戏,也是中国民间传统的体育游戏之一.跳房子的游戏规则如下:  在地面上确定一个起点,然后在起点右侧画 n 个格子,这些格子都在同一条直线 ...