在Django开发中,模型(Model)是连接业务逻辑与数据库的核心桥梁。它不仅定义数据结构,还通过元数据控制数据库行为,通过继承实现代码复用。...注意:auto_now在QuerySet.update()时不会生效,需手动调用save()。4....)最佳实践:表名使用小写字母和下划线,如order_detail。...代理模型与表管理managed:控制Django是否管理表生命周期:class Meta: managed = False # 适用于遗留数据库表,Django不会创建或删除该表场景:集成已有数据库时...,避免Django自动修改表结构。
在Django开发中,模型(Model)是连接业务逻辑与数据库的核心桥梁。它不仅定义数据结构,还通过元数据控制数据库行为,通过继承实现代码复用。...注意:auto_now在QuerySet.update()时不会生效,需手动调用save()。 4....) 最佳实践:表名使用小写字母和下划线,如order_detail。...代理模型与表管理 managed:控制Django是否管理表生命周期: class Meta: managed = False # 适用于遗留数据库表,Django不会创建或删除该表 场景:集成已有数据库时...,避免Django自动修改表结构。
django是一套开发成本低、迭代周期快的python web框架,而如mysql等关系数据库则是网站的必备组件,django通过设计一套python对象与数据库表的映射系统ORM,使得开发者不用写一行...所以当我们执行SQL操作时,比如查询整表,可以如下: articles = Article.objects.all() 当我们查询时,大多会查询到多行数据,比如上面的all方法返回的是整张表的全部行。...,查询就不会被django执行。...通常,我们可以在Model基类中提供一个方法或者成员,返回一个包含QuerySet中方法的对象(QuerySet表示若干行,所以此时不能直接返回QuerySet),而django选择提供一个成员叫objects...所以,虽然用户描述表的Model类并没有使用元类,但仍然隐式得通过基类django.db.models.base.Model类使用了上面的ModelBase元类。
:(在django中,根据代码中的类自动生成数据库的表也叫--code first) ORM:Object Relational Mapping(关系对象映射) 类名对应------》数据库中的表名 类属性对应...,不用管黑盒子是MySQL、Oracle、sqlite还是其他乱七八糟的数据库,它都会按照我们的需求输出正确的操作。...DateField.auto_now: 每次修改都会将当前时间更新进去,只有调用,QuerySet.update方法将不会调用。...而且这两个内容在全部表中都可以被应用到。所以我们封装一个基类好了。...之后修改models之后在使用makemigrations [app name] 和migrate [app name]就可以修改表结构了。
模型继承 模型继承在 Django 中与普通类继承在 Python 中的工作方式几乎完全相同,但也仍应遵循本页开头的内容。这意味着其基类应该继承自 django.db.models.Model。...CommonInfo 模型不能用作普通的 Django 模型,因为它是一个抽象基类。它不会生成数据表,也没有管理器,也不能被实例化和保存。...由于Python继承的工作方式,如果子类从多个抽象基类继承,则默认情况下仅继承第一个列出的类的 Meta 选项。为了从多个抽象类中继承 Meta 选项,必须显式地声明 Meta 继承。...外键 或 多对多字段 使用了 related_name 或 related_query_name,你必须为该字段提供一个 独一无二 的反向名字和查询名字。...多表继承 Django 支持的第二种模型继承方式是层次结构中的每个模型都是一个单独的模型。每个模型都指向分离的数据表,且可被独立查询和创建。
常用字段 (1) AutoField 自增的整型字段,必填参数primary_key=True,则成为数据库的主键,无该字段时,django会自动创建主键id字段。...在使用Model.save()保存时有效,使用QuerySet.update() 时不会自动更新。 auto_now_add:新创建对象时自动添加当前日期时间,用于“创建时间”时使用。...如果ImageField调用了,则mug_shot可以使用来获取摸板中图像的绝对路径。...为了便于查询这些属性,ImageField有两个额外的可选参数。在数据库中创建的为varchar列,默认最大长度为100字符。...Django会自动创建中间的链接表来表示多对多的关系。
SQL的一些保留字如`join,where,select则是可以在model的字段名称中使用的,因为Django在每次SQL查询中避免了可能发生的冲突。...假设我们建立了两个model,定义如下: 数据的插入 以上代码执行后,会在mysql数据库的myapp_grades数据表中插入一条数据。...抽象基类 抽象基类在你想要在你的模型中加入一些信息的时候很有用。在元数据中将基类的参数abstract=True,这样,该model就不会被用来创建任何数据表。...CommonInfo模型不能被用作是一个正常的Django模型,因为他是一个抽象基类,它不会生成数据库表或者有manager,不能被直接实例化或者保存。...如果子类想要拓展父Meta类,需要先继承,再拓展: Django对于抽象基类Meta类做了调整:在使用Meta属性的时候,会设置abstract=False 。
真正的使用了哪些索引,由 key 决定 rows:MySQL 优化器会估算此次查询需要扫描的数据记录数(行数),这个值越小,查询效率越高 Extra: 这是查询语句所对应的“额外信息”, 常见的有...是 为 了 加 快 查 询 的 速 度 , 如 果 没 有 索 引 , M y S Q L 在 查 询 时 , 只 能 从 第 一 条 记 录 开 始 然 后 读 完 整 个 表 找 到 匹配 的 行...索引类型及操作 索引类型 普通索引 这 是 最 基 本 的 索 引 类 型 , 支 持 单 列 和 多 列 。...注 意 , 如 果 是 多 列 共 同 构 成 唯 一 索 引 , 代 表 的 是 多 列 的 数 据 组 合 是 唯 一 的 。...索引使用的原则 关 于 索 引 的 使 用 原 则 , 美 团 点 评 技 术 团 队 的 文 章 《 M y S Q L 索 引 原 理 及 慢 查 询 优 化 》 里 总 结 的 很 好 , 如
抽象基类 如果你想把某些公共信息添加到很多 model 中,抽象基类就显得非常有用。你编写完基类之后,在 Meta 内嵌类中设置 abstract=True ,该类就不能创建任何数据表。...Meta 继承 创建抽象基类的时候,Django 会将你在基类中所声明的有效的 Meta 内嵌类做为一个属性。如果子类没有声明它自己的 Meta 内嵌类,它就会继承父类的 Meta 。...每个子 model 都有专属的数据表,都可以查询和创建数据表。继承关系在子 model 和它的每个父类之间都添加一个链接 (通过一个自动创建的 OneToOneField 来实现)。...但是在某些受限的情况下,子类可以从父类继承某些 Meta :如果子类没有指定 django.db.models.Options.ordering 属性或 django.db.models.Options.get_latest_by...不管你怎么改动,都不会在查询 User 时得到 MyUser。 基类的限制 代理 model 必须继承自一个非抽象基类。你不能继承自多个非抽象基类,这是因为一个代理 model 不能连接不同的数据表。
{% extends "父模板路径"%} 子模版不用填充父模版中的所有预留区域,如果子模版没有填充,则使用父模版定义的默认值。 填充父模板中指定名称的预留区域。...AutoField的选项使用 unique 如果为True, 这个字段在表中必须有唯一值,默认值是False 外键 在设置外键时,需要通过on_delete选项指明主表删除数据时,对于外键引用表数据如何处理...python manage.py makemigrations 2、迁移生成表 python manage.py migrate mysql数据库中: desc 表名;查看表结构 在我们迁移的时候,Django...的子应用会默认为我们创建一些表, 4.4演示工具使用 4.4.1shell工具 Django的manage工具提供了shell命令,帮助我们配置好当前工程的运行环境(如连接好数据库等),以便可以直接在终端中执行测试...tail -f /var/log/mysql/mysql.log # 可以实时查看数据库的日志内容 # 如提示需要sudo权限,执行 # sudo tail -f /var/log/mysql/mysql.log
也就是说,如果视图定义语句中的select语句中使用了星号"*"表示所有列,在创建视图的时候会转化为对应的列名存储在视图定义语句中,所以如果基表中新增了列将不会被视图的SQL语句检索到。...在SQL Server中,如果在视图定义语句中使用了order by但却没有使用top子句,则直接报错。...例如在引用视图时会将视图名替换成基表名,将查询涉及的列替换成基表中的列名等。 temptable将视图的结果放入临时表中,然后使用该表的数据执行对应语句操作。...由于是merge算法的视图,在引用视图(此处是查询操作)的时候,会将视图中的各项替换为基表t中的各项。包括: "*"号替换为vf1和vf2,它们又替换为t表中的id和name。...因为merge算法结合了基表,因此它有一些限制,出现了以下情况时不能使用merge算法: HAVING LIMIT GROUP BY DISTINCT UNION UNION ALL 使用了聚合函数,如
Django 在必要的时候会自动大写首字母。 关系 显然,关系数据库的威力体现在表之间的相互关联。...抽象基类 当你想将一些常见信息存储到很多model的时候,抽象化类是十分有用的。你编写完基类之后,在 Meta类中设置 abstract=True ,该类就不能创建任何数据表。...元 继承 当一个抽象类被创建的时候, Django会自动把你在基类中定义的 Meta 作为子类的一个属性。如果子类没有声明自己的Meta 类, 他将会继承父类的Meta....每个子 model 都有专属的数据表,都可以查询和创建数据表。 继承关系在子 model 和它的每个父类之间都添加一个链接 (通过一个自动创建的 OneToOneField来实现)。 ...查询集始终返回请求的模型 也就是说,没有办法让DJango在查询Person对象时返回MyPerson对象。Person 对象的查询集会返回相同类型的对象。
e in a: print (e.blog.name) len(l) 遍历时,每次都要查询数据库,l长度每次增1,Django提供了方法可以在查询时返回关联表实体,如果是onetoone...另外,通过查询connection.queries[-1]可以看到Sql语句用了join。...中的实现 在SQL中,很多关键词在删、改、查时都是可以用的,如order by、 like、in、join、union、and、or、not等等,我们以查询为例,说一下django如何映射SQL的这些关键字的...的所有字段值,即使在查询时关联了其它表,关联表的字段也不会返回,只有当我们通过Author instance用关联表时,Django才会再次查询数据库获取值。...看下面两段代码,这两段代码在1.1中提到过。在代码1中,在遍历a前,先执行a对应的SQL,拿到数据后,然后再遍历a,而遍历过程中,每次都还要查询数据库获取关联表。
使用MySql数据库 在虚拟环境中安装mysql包 pip install mysql-python 在mysql中创建数据库 create databases test charset=utf8...定义模型类 在模型中定义属性,会生成数据库表中的字段 django根据属性的类型确定以下信息: 当前选择的数据库支持字段的类型 渲染管理表单时使用的默认html控件 在管理站点最低限度的验证 django...会为表增加自动增长的主键列,每个模型只能有一个主键列,如果使用选项设置某属性为主键列后,则django不会再生成默认的主键列 属性命名限制 不能是python的保留关键字 由于django的查询方式,不允许使用连续的下划线..., 则在表中会为此字段创建索引 default:默认值 primary_key:若为 True, 则该字段会成为模型的主键字段 unique:如果为 True, 这个字段在表中必须有唯一值 8....说明: init 方法已经在基类models.Model中使用,在自定义模型中无法使用 在模型类中增加一个类方法保存数据到数据库 class BookInfo(models.Model): @classmethod
如没有WHERE子句,则更新所有的行。...两个_则表示两个字符:__ */ -- 逻辑运算符 在多个条件直接可以使用逻辑运算符...,则不允许在子表上进行insert/update --外键约束对父表的含义: 在父表上进行update/delete以更新或删除在子表中有一条或多条对 -...(了解) ------No action方式 在mysql中同Restrict,如果子表中有匹配的记录,则不允许对父表对应候选键 -- 进行update/delete操作(了解) 多表查询 准备表...带EXISTS关键字的子查询 -- EXISTS关字键字表示存在。在使用EXISTS关键字时,内层查询语句不返回查询的记录。 -- 而是返回一个真假值。
,它是 SQL 中的一个重要概念.视图建立在已有表的基础上, 视图赖以建立的这些表称为基表.视图的创建和删除只影响视图本身,不影响对应的基表。...另外当视图定义出现如 下情况时,视图不支持更新操作: 在定义视图的时候指定了“ALGORITHM = TEMPTABLE”,视图将不支持INSERT和DELETE操作; 视图中不包含基表中所有被定义为非空又未指定默认值的列...,视图将不支持INSERT操作; 在定义视图的SELECT语句中使用了 JOIN联合查询 ,视图将不支持INSERT和DELETE操作; 在定义视图的SELECT语句后的字段列表中使用了 数学表达式 或...、 UNION 等,视图将不支持INSERT、UPDATE、DELETE; 在定义视图的SELECT语句中包含了子查询,而子查询中引用了FROM后面的表,视图将不支持 INSERT、UPDATE、DELETE...数据安全 MySQL将用户对数据的 访问限制 在某些数据的结果集上,而这些数据的结果集可以使用视图来实现。用户不必直接查询或操作数据表。这也可以理解为视图具有隔离性 。
Django中基表的设置 通过图书管理系统引入多表操作:如果我们创建表的方式是先抽象出表与表之间相同的字段建一个父类,然后在用每个表类去继承这个父类,如下面的代码,我们将无法得到期望的表字段。...反过来先操作表B后操作表A,更满足逻辑思维,一样可以执行。通过逻辑将A、B表进行连表查询,不会有任何异常。如两张表建立了一对一外键字段,外键在A表,那么先往B表写数据就更合理。...值,related_name的默认值是表名小写 + _set,这就是为什么在Django中跨表反向查询时我们使用表名小写 + _set去查另一张表的数据。...子序列化 Django中的子序列化的功能是:通过跨表查询数据然后对跨表查到的数据反序列化。...(many=True) #在本例中子查询就是当我们查publisher的时候可以,通过子序列化的方式将出版社所出版的书的信息也查询出来,这其实是一个联表查询。
#创建名为my_django的虚拟环境 pip3 install Djiango #下载Django 如果下载失败请将pip更换为国内源 2 创建项目 django-admin startproject...#如果下载失败请将pip更换为国内源 或者指定下载对应版本 pip3 install django==3.0.5 #查看Django版本 django-admin --version 创建django...如果为假,则必须有值。 choices 元组值,一个用来选择值的2维元组。第一个值是实际存储的值,第二个用来方便进行选择。...无效则抛出 django.core.validators.ValidationError 异常。...,查询结果包含多条的话会报错 在view.py中添加 from .models import UserInfo def index(request): context = {
它特别适用于包含范围条件(如BETWEEN、等)的查询,以及需要通过辅助索引访问表数据的场景。 二、MRR优化的背景 在InnoDB中表数据是通过聚集索引组织的。...当缓冲区满或查询结束时,MySQL会对缓冲区中的主键值进行排序。排序的目的是为了将随机访问转换为顺序访问。 顺序访问基表: 排序后的主键值将按照顺序被用来访问基表,检索出完整的数据行。...适用于多种查询类型:MRR优化不仅适用于范围查询(如BETWEEN、等),还适用于等值连接(equi-join)等需要回表访问的场景。 五、磁盘预读机制 MRR优化充分利用了磁盘预读机制。...但是,并非所有查询都能从MRR优化中受益。如,当查询完全基于索引元组中的信息(即使用覆盖索引)时,MRR优化就没有必要,因为此时无需回表访问基表数据。...排序的目的是为了后续的顺序访问基表。 顺序访问基表: 使用排序后的主键值,MySQL将顺序访问orders表的基表部分,检索出完整的订单数据行。
verbose_name_plural = '复数名' Django对于数据库操作是惰性的,尽量不对数据库进行积极的修改,如设置的default值将不参与表的字段生成,只会参与实际插值。...,Mysql的InnoDB引擎使用行锁,因此F对象的本质是使用了数据库中的锁。...聚合查询 聚合查询是指对一个表中的一个字段的数据进行部分或全部进行统计查询。 分为整表聚合和分组聚合。...正向查询:从外键查对象 反向查询:从对象查外键 调用反向属性查询到关联的一方 一对多查询 核心:正向属性(authors)和反向属性(book_set) 在多表上设置外键,关联一表。...(publisher=pub1) 多对多映射 核心:正向属性(authors)和反向属性(book_set) mysql中多对多需要用三张表实现 Django中无需手动创建第三张表,Django自动完成