QuerySet QuerySet本身可以在不访问数据库的情况下构造、过滤、切片或复制和分配。只需要在需要从数据库检索数据或将数据保存到数据库时访问数据库。...有关拾取QuerySet的详细信息,请参阅下一节。在本节中,从数据库中读取结果非常重要。 repr()调用repr()时,将执行QuerySet。...Django为此提供了count()方法。 Pickle 序列化 QuerySet 如果pickle以序列化QuerySet,这将强制在pickle序列化之前将所有结果加载到内存中。...这意味着当取消缓存QuerySet时,它包含缓存时的结果,而不是数据库中当前的结果。 如果只想提取将来从数据库中重新创建QuerySet所需的信息,请提取QuerySet的查询属性。...annotation()的每个参数都是一个注释,将添加到返回的QuerySet中的每个对象。 Django提供的聚合函数在以下聚合函数中进行了描述。
在Django中具体的对应方式为: 类名对应数据库中的表名 类名对应数据库中的表名 类属性对应数据库里的字段 类实例对应数据库表里的一行数据 类实例对象的属性对应这行中的字段的值 一.数据库的连接 Django...文件中加上 import pymysql pymysql.install_as_MySQLdb() 二.表的创建 1.一个简单的创建 数据库表的创建在ORM中就是类的创建。...一对一的创建即在外键创建好后给school_id添加UNIQUE=True的属性 3.多对多 teacher=models.ManyToManyField(teacher) 这样Django会默认添加一张表为...,values返回的是一个字典序列 count(): 返回数据库中匹配查询(QuerySet)的对象数量。...2.QuerySet对象 查询的结果集就是一个QuerySet对象 QuerySet对象就像是一个列表,列表存储着查询出的结果,可以迭代,可以切片 Django中QuerySet对象是惰性的,即你得到这个对象的时候并没有真正的在数据库中执行
MySQL PyMySQL(纯python的mysql驱动程序) 3 在django的项目中会默认使用sqlite数据库,在settings里有如下设置: ?...: '', #你的数据库主机,留空默认为localhost 'PORT': '3306', #你的数据库端口 } } 注意: NAME即数据库的名字,在mysql连接前该数据库必须已经创建...(如何处理外键关系的字段如一对多的publisher和多对多的authors) #一对多(ForeignKey): #方式一: 由于绑定一对多的字段,比如publish,存到数据库中的字段名叫...所以使 #用iterator()的时候要当心,确保你的代码在操作一个大的queryset时没有重复执行查询 总结: queryset的cache是用于减少程序对数据库的查询,在通常的使用下会保证只有在需要的时候才会查询数据库...__city或者author__name中的publisher,author是book表中绑定的字段 #一对多和多对多在这里用法没区别 # 反向查找(条件) #反向查找之一对多:
/多对多关系(Spanning multi-valued relationships) 这部分是Django 1.0中新增的: 请查看版本记录 如果你的过滤是基于 ManyToManyField 或是逆向...上述原则同样适用于 exclude():一个单独 exclude() 中的所有筛选条件都是作用于同一个实例 (如果这些条件都是针对同一个一对多/多对多的关系)。...多对多关系 在多对多关系的任何一方都可以使用 API 访问相关联的另一方。多对多的 API 用起来和上面提到的 “逆向” 一对多关系关系非常相象。...一对一关系 相对于多对一关系而言,一对一关系不是非常简单的。如果你在 model 中定义了一个 OneToOneField 关系,那么你就可以用这个字段的名称做为属性来访问其所关联的对象。...任何一个 model 在第一次调用时,Django 就会遍历所有的 INSTALLED_APPS 的所有 models,并且在内存中创建中必要的反向连接。
Django的数据模型的建立过程很简单,就是继承django.db.models中的Model类,然后给它增加属性。每一个属性可以对应关系数据库中的一个字段。...关系 Django中的一对一、多对一、多对多关系可以通过下面方式表达: from django.db import models class Company(models.Model): name...,用到一对一、多对一、多对多关系。...需要注意的是,在Django ORM中,只能通过ForeignKey来定义多对一关系,不能显示地定义一对多关系。但你可以使用模型对象的*_set语法来反向调用多对一关系。...因此,在写程序时,要注意QuerySet求值的时间点,避免重复的数据库操作。 SQL的WHERE条件可以通过参数的形式来传给方法。
对应app目录下的models.py 1、生成一个简单的数据库表: 在未指定primary_key的情况下,Django会默认创建一个id自增字段作为主键。...一对一其实就是 一对多 + 唯一索引 # 2.当两个类之间有继承关系时,默认会创建一个一对一字段...=2) #创建书的出版社信息,其与出版社的外键关系为一对多,所以用外键 publish = models.ForeignKey(Publish) #创建书的出版日期...QuerySet是惰性执行的,创建Query Set不会访问数据库,只有在访问具体查询结果的时候才会访问数据库。..."QuerySet is empty" 总结: QuerySet.exists() > QuerySet.count()==0 > QuerySet 2、模板中显示数据库内容的方法 a、创建数据库
答:使用F对象,被定义在django.db.models中。 语法如下: F(属性名) 例:查询阅读量大于等于评论量的图书。...聚合函数包括:Avg平均,Count数量,Max最大,Min最小,Sum求和,被定义在django.db.models中。 例:查询图书的总阅读量。...1的书籍信息 由一到多的访问语法: 一对应的模型类对象.多对应的模型类名小写_set 例: >>> book = BookInfo.objects.get(id=1) >>> book.peopleinfo_set.all...查询集,也称查询结果集、QuerySet,表示从数据库中获取的对象集合。 当调用如下过滤器方法时,Django会返回查询集(而不是简单的列表): all():返回所有数据。...2 两大特性 1)惰性执行 创建查询集不会访问数据库,直到调用数据时,才会访问数据库,调用数据的情况包括迭代、序列化、与if合用 例如,当执行如下语句时,并未进行数据库查询,只是创建了一个查询集books
作用: 通常是对数据库中的字段值在不获取的情况下进行操作 用于类属性 (字段) 之间的比较。...='机械工业出版社')) 原生的数据库操作方法 使用MyModel.objects.raw()进行 数据库查询操作查询 在django中,可以使用模型管理器的raw方法来执行select语句进行数据查询...中的游标cursor对数据库进行 增删改查 操作 在 Django 中跨过模型类直接操作数据库 使用步骤: 导入 cursor 所在的包 Django 中的游标 cursor 定义在 django.db.connection...: 一对一映射 如: 一个身份证对应一个人 一对多映射 如: 一个班级可以有多个学生 多对多映射 如: 一个学生可以报多个课程,一个课程可以有多个学生学习 一对一映射 一对一是表示现实事物间存在的一对一的对应关系...) except: print(author2.name, '还没有妻子') 一对多映射 一对多是表示现实事物间存在的一对多的对应关系。
Django 关系字段 本文主要内容是关于Django框架中models的知识小结 #1 环境 Python3.7.3 Django==2.0.7 #2 字段 #2.1 一对多(ForeignKey)...一对多 : fk字段在"多"的models中定义 from django.db import models class Blog(models.Model): name = models.CharField...与之关联的值设置为可执行对象的返回值,设置:models.SET(可执行对象) #2.4 数据库表示 在生成数据库时,Django追加"_id"字段名称来创建其数据库列名,可以通过指定显式更改此内容db_column....RelatedManager object at 0x10d58c908> >>> b.entryblogs.all() # 一对多,所以反向获取到的数据是一个多条数据,需要all()...(to,**options) MtoM字段根据需求可以放到两个有关联的表中的任意一个 from django.db import models class Author(models.Model):
深入模型 在上一个章节中,我们提到了Django是基于MVC架构的Web框架,MVC架构追求的是“模型”和“视图”的解耦合。所谓“模型”说得更直白一些就是数据(的表示),所以通常也被称作“数据模型”。...在MySQL中创建数据库的SQL语句如下所示: create database oa default charset utf8; Django框架本身有自带的数据模型,我们稍后会用到这些模型,为此我们先做一次迁移操作...> 说明1:由于员工与部门之间存在多对一外键关联,所以也能通过部门反向查询该部门的员工(从一对多关系中“一”的一方查询“多”的一方),反向查询属性默认的名字是类名小写_set(如上面例子中的emp_set...说明2:查询多个对象的时候返回的是QuerySet对象,QuerySet使用了惰性查询,即在创建QuerySet对象的过程中不涉及任何数据库活动,等真正用到对象时(求值QuerySet)才向数据库发送SQL...managed 设置为True时,Django在迁移中创建数据表并在执行flush管理命令时把表移除 order_with_respect_to 标记对象为可排序的 ordering 对象的默认排序 permissions
在Django MVC概述和开发流程中已经讲解了Django的MVT开发流程,本文重点对MVT中的模型(Model)进行重点讲解。 配置MySQL数据库 确保已经安装了操作mysql的包。...不会生成数据库,所以需要手动创建数据库。...查询集(QuerySet对象) 调用all, filter, exclude, order_by这些函数会返回一个查询集(QuerySet对象),查询集有以下特性: 惰性查询:只有在实际使用查询集中的数据的时候才会发生对数据库的真正查询...对象调用count方法,返回值是一个整数 # 查询所有学生的数量 StudentInfo.objects.all().count() 关联查询 一对多关系 # 学校类-学生类 # 定义在多的类(学生类)...中 school = models.ForeignKey() 在一对多关系中,一对应的类简称一类,多对应的类简称做多类,多类中定义的建立关联的类属性叫做关联属性。
myapp_modelName,是根据 模型中的元数据自动生成的,也可以覆写为别的名称 2、id 字段是自动添加的 3、对于外键字段,Django 会在字段名上添加"_id" 来创建数据库中的列名...这些参数在文档中有详细定义,这里我们只简单介绍一些最常用的: (1)null 如果为True,Django 将用NULL 来在数据库中存储空值。 默认值是 False....class RelatedManager "关联管理器"是在一对多或者多对多的关联上下文中使用的管理器。它存在于下面两种情况: ForeignKey关系的“另一边”。像这样: ?...然而,在多对多关系中使用add()并不会调用任何 save()方法,而是由QuerySet.bulk_create()创建关系。...() # 与人民出版社关联的所有书籍对象集合 基于双下划线的跨表查询 Django 还提供了一种直观而高效的方式在查询(lookups)中表示关联关系,它能自动确认 SQL JOIN 联系。
上一篇章讲述了如何创建项目,本篇章主要讲解Django的模型设计。 参考文献 Django 官网 2.1 文档 一般操作数据库是通过写sql语句,那么能不能不写sql语句就可以操作数据库呢?...使用django进行数据库开发的步骤如下: 1.在models.py中定义模型类 2.迁移 3.通过类和对象完成数据增删改查操作 下面我们以保存服务器资产信息为例来给大家介绍Django中进行数据库开发的整个流程...2.激活模型 上面的一小段用于创建模型的代码给了 Django 很多信息,通过这些信息,Django 可以: 为这个应用创建数据库 schema(生成 CREATE TABLE 语句)。...同时我们发现多了一个id项,这一项是Django框架帮我们自动生成的,在创建表的时候id就会作为对应表的主键列,并且主键列自动增长。...,ServerInfo类和MiddlewareInfo类之间具有一对多的关系,这个一对多的关系应该定义在多的那个类,也就是MiddlewareInfo类中。
创建Django项目的简单流程 创建一个django project django-admin startproject 项目名 在项目名目录下创建应用 python manage.py startapp...SQL语句,然后去数据库中执行 方法2:在pycharm中启动manage.py控制台 ?...) 从数据库中查询出来的结果一般是一个集合,这个集合叫做 QuerySet all(): 查询所有结果 Returns a new QuerySet all() QuerySet...() print(ret) count(): 返回数据库中匹配查询(QuerySet)的对象数量。...,通过它与Author表产生关系,从而创建关系表app01_book_author ---- 注意了: Book里这个author只是这个类的属性,在最终生成的数据库表中并没有这个字段,只是用于orm
2.配置关系型数据库MySQL 1.创建数据库 在MySQL中创建数据库,创建用户,授权用户访问该数据库。...all privileges on vote.* to 'django'@'%'; flush privileges; 2.创建表 在MySQL中创建保存学科和老师信息的二维表(保存用户信息的表稍后处理...利用Django的ORM,我们可以直接将刚才创建的学科表和老师表变成Django中的模型类。...: Teacher object (3)>]> 说明1:由于老师与学科之间存在多对一外键关联,所以能通过学科反向查询到该学科的老师(从一对多关系中“一”的一方查询“多”的一方),反向查询属性默认的名字是类名小写...说明2:ORM查询多个对象时会返回QuerySet对象,QuerySet使用了惰性查询,即在创建QuerySet对象的过程中不涉及任何数据库活动,等真正用到对象时(对QuerySet求值)才向数据库发送
要求 修改数据库 Django shell 数据级联(一对多) 元信息 定义字段 模型过滤 创建对象4种方式 查询集 过滤器 获取单个对象 字段查询 时间 聚合函数 跨关系查询 F对象 Q对象...学习课程 1.修改数据库 ① 在settings中的DATABASES中进行修改 ‘ENGINE’: ‘django.db.backends.mysql’, ’NAME‘ : 数据库名字 ’USER‘:..., 这个字段在表中必须有唯一值 关系 ·分类 ·ForeignKey:一对多,将字段定义在多的端中 ·ManyToManyField:多对多,将字段定义在两端中 ·OneToOneField...·unique ·如果为 True, 这个字段在表中必须有唯一值 关系 ·分类 ·ForeignKey:一对多,将字段定义在多的端中 ·ManyToManyField...:多对多,将字段定义在两端中 ·OneToOneField:一对一,将字段定义在任意一端中 ·用一访问多 ·格式 ·对象.模型类小写_set ·示例 grade.students_set
django框架对orm层强大的shell api使得开发者可以轻松地开发和变更数据库表操作,真正符合了DRY(don’t repeat yourself)原则。...我打算和朋友合写一个中文的django教程,先在这里进行总结一下简单的数据库api。...>]> # 如果结果不存在filter方法返回空的QuerySet >>> Question.objects.filter(id=2) QuerySet []> # 得到今年的所有问题 >>> from...关联查询 # 使用pk或者id是一样的都是默认主键 >>> q = Question.objects.get(pk=1) # 使用关联关系一对多的表名加_set来处理关联的记录 >>> q.choice_set.all...() QuerySet []> # Create方法有两个作用,创建了一个实例,并且insert到了数据库中 >>> q.choice_set.create(choice_text='Not much
领取专属 10元无门槛券
手把手带您无忧上云