本篇主要介绍我们在使用django框架开发的时候使用的操作数据库的语句,这在动态网站部分是很重要的,因为我们需要连接数据库进行操作,然后把数据处理的结果显示在前端页面上,在其他地方我们都是直接用sql语句来手动输入...用save()方法实现,如下所示: b5.name = 'New name b5.save() 保存外键和多对多关系的字段 更新外键字段和普通的字段一样,只要指定一个对象的正确类型。...blog_name=’Beatles Blog’的Entry对象 Entry.objects.filter(blog__name__exact='Beatles Blog') 查找blog表中外键关系entry...表中的headline字段中包含Lennon的blog数据 Blog.objects.filter(entry__headline__contains='Lennon') 查找blog表中外键关系entry...表中的author字段中包含Lennon的blog数据 Blog.objects.filter(entry__author__name='Lennon') 查询的是author_name为null的值
重点内容回顾-DRF 1. on_delete on_delete是定义模型类中外键的一个选项。 on_delete选项指明的是主表删除数据的时候,对于外键引用的表数据如何处理。...在django.db.models中包含了可选的常量,常用的有三种: a.CASCADE级联,删除主表数据的时候,连同删除外键表中的数据。这个就有点狠了,按需求慎用。...read_only=True参数的时候,该字段仅仅用在序列化。...包含queryset参数的时候,将被用在反序列化时参数校验。...request.data保存的是解析之后的请求体的数据,并且已经解析成了字典或类字典,相当于包含Django原始request对象中的request.body/request.POST/request.FILES
migrate 命令将只为INSTALLED_APPS中的应用运行数据库的迁移。 创建模型 现在定义该应用的模型——本质上,就是定义该模型所对应的数据库设计及其附带的元数据。...有了这些代码,Django就能够: 为该应用创建数据库表(CREATE TABLE 语句); 为Question对象和Choice对象创建一个访问数据库的python API。...要在我们的项目中包含应用程序,我们需要在INSTALLED_APPS设置中添加对其配置类的引用。...不用在意DEFERRABLE部分;它只是告诉PostgreSQL直到事务的最后再执行外键关联; 这些SQL语句是针对你所使用的数据库定制的,所以会为你自动处理某些数据库所特有的字段例如auto_increment...有关如何使用双下划线通过API执行字段查找的更多信息,请参阅字段查找。有关数据库API的完整详细信息,请参阅我们的数据库API参考。
从效果上说,它其实是创建了一个可在编程语言里使用的—“虚拟对象数据库”。...在Django中具体的对应方式为: 类名对应数据库中的表名 类名对应数据库中的表名 类属性对应数据库里的字段 类实例对应数据库表里的一行数据 类实例对象的属性对应这行中的字段的值 一.数据库的连接 Django...这里的id是自动创建的,school_id是school添加外键产生的 如果想要与另一张表的其他字段添加外键,需要在加上参数to_filed=’字段名’,同时这个字段必须是unique=True 2.一对一...——一个特殊的QuerySet,运行后得到的并不是一系列 model的实例化对象,而是一个可迭代的字典序列 exclude(**kwargs): 它包含了与所给筛选条件不匹配的对象 order_by(*...import Q Q查询是应用在查询条件上的。
本章知识点 1、Django模型关系字段介绍与使用 2、Django模型关系字段查询 知识点讲解 1、Django模型关系字段介绍与使用 业务主体间的关系 学生 和 专业 关系 一个学生对应一个专业...ManyToManyField 一个老师教过的所有学员 一个学员所有的老师 外键 专业 一 学生 多 外键字段 对应 专业表的主键 我们研究这两种关系,从以下的两个角度 1、...数据表 一对多正常生成数据表 多对多额外生成关系表 关系表的结构如下: 一个老师有多个学生 老师表里无法表示多个学生 一个学生有多个老师 学生表里无法表示多个老师 创建了关系表...模型关系字段查询 1、外键 查询学生对应的项目 这样的查询时候最简单的,学生当中外键字段对应的就是外键的完整信息,可以直接获取 项目对应的所有学生 视图部分 前端部分...2、多对多数据 老师和学生 老师对应所有学生 学生对应的所有老师 本章总结 Django模型关系字段介绍与使用 Django模型关系字段查询
4.数据库 ORM框架: 作用:将模型类和数据表进行对应,通过面向对象的方式进行数据库的操作。 flask中SQLALchemy Django中自带ORM框架,可以直接进行使用。...导入 pymysql.install_as_MySQLdb()调用方法 sqlite是小型的数据库,用在手机里,默认的是它。...字段类型 类型 说明 AutoField 自动增长的IntegerField,通常不用指定,不指定时Django会自动创建属性名为id的自动增长属性 BooleanField 布尔字段,值为True或False...AutoField的选项使用 unique 如果为True, 这个字段在表中必须有唯一值,默认值是False 外键 在设置外键时,需要通过on_delete选项指明主表删除数据时,对于外键引用表数据如何处理...,在django.db.models中包含了可选常量: CASCADE 级联,删除主表数据时连通一起删除外键表中数据 PROTECT 保护,通过抛出ProtectedError异常,来阻止删除主表中被外键应用的数据
有了它,Django 可以: 为这个应用程序创建一个数据库模式(创建表语句)。 创建用于访问问题和选择对象的 Python 数据库访问 API。...按照惯例,Django 会将"_id"附加到外键字段名。(是的,你也可以重写这个。) 外键关系是通过外键约束来显式的。...字段名的引号也是一样——例如,使用双引号或单引号。 sqlmigrate 命令实际上并没有在数据库上运行迁移—相反,它将迁移结果打印到屏幕上,以便您可以看到 SQL Django 认为需要什么迁移。...通常,您需要定制管理表单的外观和工作方式。可以通过在注册对象时告诉 Django 所需的选项来实现。 通过重新排列编辑表单中的字段来了解其工作原理。...“添加选择”表单如下所示: 在该表单中,“Question”字段是一个选择框,包含数据库中的每个问题。Django 知道一个外键应该在管理中表示为一个框。在我们的例子中,目前只存在一个问题。
对象关系映射,是随着面向对象思想发展而产生的,是一种程序技术,用于实现面向对象编程语言里不同类型系统的数据之间的转换,面向对象是从软件工程基本原则(如耦合、聚合、封装)的基础上发展起来的,而关系数据库则是从数学理论发展而来的...:自动增长的IntegerField,通常不用指定,不指定时Django会自动创建属性名为id的自动增长属性 BooleanField: 布尔字段,值为True或False NullBooleanField...= False ALLOWED_HOSTS = ['*', ] HttpReqeust对象 path: 一个字符串,表示请求的完整路径,不包含域名和参数 method: 一个字符串,表示请求方法,常用的有...,包含post请求方式的所有参数 FILES:一个类似于字典的对象,包含所有的上传文件 COOKIES:一个标准的Python字典,包含所有的cookie,键和值都为字符串 session:一个可读写的类似于字典的对象...'fields':('字段3','字段4')}), ) 上传图片 创建包含图片类型字段的模型类 将模型的类型定义成ImageField字段 class Pic(models.Model): pic
网站:http://python.usyiyi.cn/django/index.html 模型 模型是有关你的数据的,简单、确定的信息源。它包含了你所储存数据的一些必要的字段和行为。...用法和其他 Field 字段类型一样:在 model 里面做为类属性包含进来。 当某个对象想扩展自另一个对象时,最常用的方式就是在这个对象的主键上添加一对一关系。...这是因为 Django 会对每个 SQL 查询的数据库名称和列名称做重编码,至于如何编码视你所用的数据库而定。...对很多应用来说,这种继承方式正是你想要的。它提供一种在 Python 语言层级上提取公共信息的方式,但在数据库层级上,各个子类仍然只创建一个数据库。...这是因为子类需要一个空间来存储不包含在基类中的字段数据。但有时,你可能只想更改 model 在 Python 层的行为实现。比如:更改默认的 manager ,或是添加一个新方法。
only only括号内放字段,查询结果是一个列表套一个个数据对象,这些数据对象点括号内的字段属性,不会再查数据库,直接就是对象获取属性;也支持点其他属性,但是其他属性会每拿一条数据就走一次数据库。...,特点:内部自动连表操作,会将括号内外键字段所关联的表与当前表自动拼接成一张表,然后将表中的数据一个一个查询出来封装成一个一个的对象。...这样做的好处:跨表查询也不需要重复走数据库,减轻数据库压力。select_related()括号内放多个外键字段,逗号隔开,会将多个外键字段关联的表与当前表拼成一张大表。...,特点:按步骤查询多张表,然后将查询结果封装到对象中,给用户的感觉好像还是连表操作,括号内支持传多个外键字段,每放一个外键字段就会多走一条SQL语句,多查一张表。...2.对JSON数据进行序列化。 3.Django后端针对json格式的数据不会做任何的处理,只是将数据原封不动的放在了request.body中,我们需要手动对其进行反序列化处理。
Django中基表的设置 通过图书管理系统引入多表操作:如果我们创建表的方式是先抽象出表与表之间相同的字段建一个父类,然后在用每个表类去继承这个父类,如下面的代码,我们将无法得到期望的表字段。...db_table = 'xxx'指定该类的数据库表单名字。当然如果不指定也没关系,Django会自动默认的按照一定规则生成数据模型对应的数据库表名。...更合理) """ Django orm中外键字段属性详解 在建表之前我们对外键字段属性进行了解: 1)related_name在外键中设置外键反向查询的字段名:正向找字段名,反向找related_name...a.事物A读取某一数据后,事物B对其作了修改,当事物A再次读取数据时,得到与前一次不同的值。...子序列化的使用方法及注意事项: 1)只能在序列化中使用 2)字段名必须是外键(正向反向都可以)字段,相对于自定义序列化外键字段,自定义序列化字段不能参与反序列化,而子序列化必须为外键名,子序列化字段不写入数据库
save() 保存外键和多对多关系的字段,如下例子: 更新外键字段和普通的字段一样,只要指定一个对象的正确类型。...exclude(**kwargs) 返回一个与参数不匹配的QuerySet,相当于不等于(!=)。...=’Beatles Blog’) 查找entry表中外键关系blog_name=’Beatles Blog’的Entry对象。...>>> Blog.objects.filter(entry__headline__contains=’Lennon’) 查找blog表中外键关系entry表中的headline字段中包含Lennon的blog...Blog.objects.filter(entry__author__name=’Lennon’) 查找blog表中外键关系entry表中的author字段中包含Lennon的blog数据。
COOKIES 客户端发送的cookie信息 files FILES 客户端上传的文件 8.响应对象构造 8.1返回HttpResponse类的对象或其子类的对象 response = HttpResponse...class Meta: db_table = '' 定义外键属性: # 表中外键字段名格式: 键属性_id> hbook = models.ForeignKey('BookInfo...python manage.py makemigrations # 迁移生成表 python manage.py migrate 13.3.4通过模型类和对象进行数据库操作(增删改查) 新增 创建模型类对象...= 值 可以写多个查询条件,默认是且的关系 F对象: 用于查询时字段之间的比较 from django.db.models import F Q对象: 用于查询时条件之间的逻辑关系 from django.db.models...() # 由多查1 多对象.外键属性 例:hero.hbook 2.通过模型类进行关联查询 # 查图书(一) 一类.objects.get|filter(多类名__字段__条件=值) 例:books =
要求 修改数据库 Django shell 数据级联(一对多) 元信息 定义字段 模型过滤 创建对象4种方式 查询集 过滤器 获取单个对象 字段查询 时间 聚合函数 跨关系查询 F对象 Q对象...在管理员站点添加了一个JavaScript写的日历控件, 和一个“Today"的快捷按钮,包含了一个额外的invalid_date错误消息键 ·注意 ·auto_now_add,...FileField的所有属性和方法,但对上传的对象进行校验,确保它是个有效的image 上两个字段依赖pillow 字段选项 ·概述 ·通过字段选项,可以实现对字段的约束 ·在字段对象时通过关键字参数指定...:每个查询集都包含一个缓存,来最小化对数据库的访问 在新建的查询集中,缓存首次为空,第一次对查询集求值,会发生数据缓存,django会将查询出来的数据做 一个缓存,并返回查询结果,以后的查询直接使用查询集的缓存...中 ·使用方式 ·导入from django.db import models ·通过models.Field创建字段类型的对象,赋值给属性 逻辑删除 ·对于重要数据都做逻辑删除
如果我们想退出循环,可以改变正在迭代的变量,让其仅仅包含需要迭代的项目。 同理,Django也不支持continue语句,我们无法让当前迭代操作跳回到循环头部。...该层处理与数据相关的所有事务: 如何存取、如何验证有效性、包含哪些行为以及数据之间的关系等 T:代表模板(Template),即表现层。...3.设置字段可选 你或许会发现管理工具有个限制:编辑表单需要你填写每一个字段,然而在有些情况下,你想要某些字段是可选的。 举个例子,我们想要Author模块中的email字段成为可选,即允许不填。...filter_horizontal和filter_vertical选项只能用在多对多字段上, 而不能用于ForeignKey字段。 默认地,管理工具使用`` 下拉框`` 来展现`` 外键`` 字段。...解决这个问题的办法是使用`` raw_id_fields`` 选项。它是一个包含外键字段名称的元组,它包含的字段将被展现成`` 文本框`` ,而不再是`` 下拉框`` 。
对应app目录下的models.py 1、生成一个简单的数据库表: 在未指定primary_key的情况下,Django会默认创建一个id自增字段作为主键。...=2) #创建书的出版社信息,其与出版社的外键关系为一对多,所以用外键 publish = models.ForeignKey(Publish) #创建书的出版日期...) 判断一个对象集合中是否包含指定对象,包含返回True,不包含返回False exclude() 排除满足条件的对象 annotate()...如果指定字段,每个字典将只包含指定的字段的键/值。如果没有指定字段,每个字典将包含数据库表中所有字段的键和值。...Q查询 F查询专门取对象中某列值的操作,F的作用:用来批量修改数据的 #导入F from django.db.models import F #把table1表中的num列中的每一个值在的基础上加10
如果指定字段,每个字典将只包含指定的字段的键/值。 如果没有指定字段,每个字典将包含数据库表中所有字段的键和值。...传递的是一个字典,其键为你想覆盖的错误信息。...Widget 负责渲染网页上HTML 表单的输入元素和提取提交的原始数据 每当你指定表单的一个字段的时候,Django 将使用适合其数据类型的默认Widget。...此选项中的任何字段(应为list或tuple)将按原样显示其数据,不可编辑;它们也被排除在用于创建和编辑的ModelForm之外。 ...如果您想在自己的管理JavaScript中使用jQuery而不包含第二个副本,则可以使用更改列表上的django.jQuery对象和添加/编辑视图。
模型 模型是你的数据的唯一的、权威的信息源。它包含你所储存数据的必要字段和行为。通常,每个模型对应数据库中唯一的一张表。...Changed in Django 1.7: 在Django 1.6 及之前的版本中,中介模型禁止包含多于一个的外键。...用法和其他字段类型一样:在模型里面做为类属性包含进来。 当某个对象想扩展自另一个对象时,最常用的方式就是在这个对象的主键上添加一对一关系。 OneToOneField要一个位置参数:与模型关联的类。...它提供一种在 Python 语言层级上提取公共信息的方式,但在数据库层级上,各个子类仍然只创建一个数据库。...代理模型 使用 多表继承时,model 的每个子类都会创建一张新数据表,通常情况下,这正是我们想要的操作。这是因为子类需要一个空间来存储不包含在基类中的字段数据。
如果指定字段,每个字典将只包含指定的字段的键/值。如果没有指定字段,每个字典将包含数据库表中所有字段的键和值。...tzinfo参数定义在截取之前将数据时间转换到的时区。 11. none() 调用none()将创建一个不返回任何对象的查询集,并且在访问结果时不会执行任何查询。...,模型可能包含大量字段,其中一些可能包含大尺寸数据(例如文本字段),将它们转换为Python对象需要花费很大的代价。...如果需要创建一个对象而该对象的主键早已存在于数据库中,IntegrityError异常将会被触发。 这个方法假设进行的是原子操作,并且正确地配置了数据库和正确的底层数据库行为。...最后建议只在Django视图的POST请求中使用get_or_create(),因为这是一个具有修改性质的动作,不应该使用在GET请求中,那样不安全。
执行查询 一旦你建立好数据模型之后,django会自动生成一套数据库抽象的API,可以让你执行增删改查的操作。这篇文档阐述了如何使用这些API。关于所有模型检索选项的详细内容,请见数据模型参考。...查询集是延迟的 QuerySets 是惰性的 – 创建 QuerySet 的动作不涉及任何数据库操作。...要编写高效代码,就要理解缓存是如何工作的。 一个 QuerySet 时刚刚创建的时候,缓存是空的。...Django 也提供反向获取关联对象的 API,就是由从被关联的对象得到其定义关系的主对象。...本质上来说,INSTALLED_APPS 的作用之一就是确认 Django 完整的 model 范围。 在关联对象上的查询 包含关联对象的查询与包含普通字段值的查询都遵循相同的规则。
领取专属 10元无门槛券
手把手带您无忧上云