Django模型简化了任务并将表组织到模型中。通常,每个模型都映射到单个数据库表。 本文围绕如何使用Django模型方便地将数据存储在数据库中展开。...此外,我们可以使用Django的管理面板来创建,更新,删除或检索模型的字段以及各种类似的操作。Django模型提供了简单性,一致性,版本控制和高级元数据处理。...模型的基础包括– 每个模型都是一个子类的Python类django.db.models.Model。 模型的每个属性代表一个数据库字段。...使用Django模型 要使用Django模型,需要在其中运行一个项目和一个应用程序。启动应用程序后,可以在app / models.py中创建模型。...Django模型中的内置字段验证是所有Django字段预定义的默认验证。
模型类必须继承自Model类,位于包django.db.models中。 提示:对于重要数据使用逻辑删除。...示例 1.打开booktest/models.py文件,定义模型类如下 from django.db import models #定义图书模型类BookInfo class BookInfo(models.Model...,每个模型只能有一个主键列,如果使用选项设置某属性为主键列后django不会再创建自动增长的主键列。...当没有为模型类定义管理器时,Django会为每一个模型类生成一个名为objects的管理器,自定义管理器后,Django不再生成默认管理器objects。...books = models.Manager() 管理器Manager 管理器是Django的模型进行数据库操作的接口,Django应用的每个模型类都拥有至少一个管理器。
每个模型对 应数据库中唯一的一张表 如何编写模型 模型:每个模型都用一个类表示,该类继承自django.db.models.Model。...字段选项——unique 如果该值设置为True,这个字段的值在整张表中必须是唯一的 模型meta选项 使用内部的class Meta 定义模型的元数据,例如: from django.db import...来表示随机排序 编写服务器模型 数据库迁移 迁移是Django用于同步你的发生改变的模型(添加一个字段,删除一个模型,等等)到你的 数据库 迁移命令 makemigrations, 负责基于你的模型修改创建一个新的迁移...这个异常是正在查询的模型类的一个属性 —— 所以在上面的代码中, 如果没有主键为1 的Entry 对象,Django 将引发一个Entry.DoesNotExist。...如果有多条记录满足get() 的查询条件,Django 也将报错。这种情况将引发 MultipleObjectsReturned,它同样是模型类自身的一个属性。
Django模型 Django的模型定义在models.py文件中。模型是MVT中的M,也相当于MVC中的M。 在Django中,模型必须继承自Model类。...class BookInfo(models.Model): # 一个模型类就会对应生成数据库中的一张表 """书籍模型""" name = models.CharField...,Django默认以小写app应用名_小写模型类名为数据库表名,一般我们会通过db_table指明数据库表名。...django会为表创建自动增长的主键列,每个模型只能有一个主键列,如果使用选项设置某属性为主键列后django不会再创建自动增长的主键列。...下面是另外一个模型,和前面的BookInfo模型通过外键关联起来。
>> https://docs.djangoproject.com/en/2.1/ref/models/fields/#field-types InterField CharFiled...2.1/ref/models/fields/#field-options primary_key auto_dreated unique指定是否为唯一 auto_now >> 通过模型类上的管理器来构造... 模型类上的管理器(class.objects) queryset (惰性,,没有操作数据库)表示数据库中对象的集合,等同于select 语句 query 获取mysql 语句 first()...*kwargs) 根据给定的条件获取过滤后的queryset,多个条件用','连接 exclude(**kwargs) 作用和filter相反,去除不符合条件的对象 多条件的or连接 from django.db.models... gt 大于 gte 大于等于 lt lte startswith istartswith endswith iendswith isnull True False 聚合 django.db.models
Django模型类开发流程 在models.py中定义模型类,要求继承自models.Model 把应用加入settings.py文件的installed_app项 生成迁移文件 执行迁移生成表 使用模型类进行...定义模型类 在模型中定义属性,会生成数据库表中的字段 django根据属性的类型确定以下信息: 当前选择的数据库支持字段的类型 渲染管理表单时使用的默认html控件 在管理站点最低限度的验证 django...定义模型属性 定义属性时,需要字段类型 字段类型被定义在django.db.models.fields目录下,为了方便使用,被导入到django.db.models中 使用方式 导入from django.db...模型类的管理器 objects:是Manager类型的对象,用于与数据库进行交互 当定义模型类时没有指定管理器,则Django会为模型类提供一个名为objects的管理器 支持明确指定模型类的管理器...Django的模型进行数据库的查询操作的接口,Django应用的每个模型都拥有至少一个管理器 自定义管理器类主要用于两种情况 向管理器类中添加额外的方法创建管理器对象保存数据到数据库 class TestInfoManager
模型关系 关系数据库的威力体现在表之间的相互关联,Django提供了三种最常见的数据库关系:多对一 (many-to-one),多对多(many-to-many),一对一(one-to-one)...多对一关系 多对多关系 一对一关系 多对一 django是使用django.db.models.ForeignKey 定义多对一关系 ForeignKey需要一个位置参数来指定本Model关联的Model...,ForeignKey关联的Model 是"一", ForeignKey所在的Model是"多" 比如汽车和制造商的例子,一辆汽车只能属于一个制造商,但是一个制造商有多辆汽车,这个关系,用Django...所在的模型) 如果模型有一个ForeignKey,那么该ForeignKey 所指的模型实例可以通过一个管理器返回前一个有ForeignKey的模型的所有实例。...ManyToManyField 的名字 在哪个模型中设置 ManyToManyField 并不重要,在两个模型中任选一个即可——不要在两个模型中都设置 一对一 一对一是通过django.db.models.OneToOneField
ORM简介 对象关系映射(Object Relation Mapping)实现了关系和数据库之间的映射,隐藏了关系数据访问的细节,不需要再编写SQL语句 创建模型 在models.py的文件中创建类 继承...models.Model from django.db import models class BookInfo(models.Model): title = models.CharField...(max_length=20) pub_date = models.DateField() 数据迁移 1生成迁移文件:根据模型类生成创建表的迁移文件。...OK Django默认采用sqlite3数据库,最终会生成如下数据表,其中自定义的表命名规则是(应用名称模型类名) DATABASES = { 'default...': { 'ENGINE': 'django.db.backends.sqlite3', 'NAME': os.path.join(BASE_DIR, 'db.sqlite3
:hname 英雄性别:hgender 英雄简介:hcontent 所属图书:hbook 图书-英雄的关系为一对多 数据库配置 在settings.py文件中,通过DATABASES项进行数据库设置 django...支持的数据库包括:sqlite、mysql等主流数据库 Django默认使用SQLite数据库 创建应用 在一个项目中可以创建一到多个应用,每个应用进行一种业务处理 创建应用的命令: python manage.py...startapp booktest 应用的目录结构如下图 定义模型类 有一个数据表,就有一个模型类与之对应 打开models.py文件,定义模型类 引入包from django.db import...models 模型类继承自models.Model类 说明:不需要定义主键列,在生成时会自动添加,并且值为自动增长 当输出对象时,会调用对象的str方法 from django.db import models...,HeroInfo from django.utils import timezone from datetime import * 查询所有图书信息: BookInfo.objects.all() 新建图书信息
通过“迁移操作”(migrate)来添加模型。 用NoSQL来应对需要降低范式级别的场景。 如果布尔类型可以为空要使用NullBooleanField。 在模型中放置业务逻辑。...模型定义参考 字段 对字段名称的限制 字段名不能是Python的保留字,否则会导致语法错误 字段名不能有多个连续下划线,否则影响ORM查询操作 Django模型字段类 字段类 说明 AutoField...primary_key 将字段指定为模型的主键,未指定时会自动添加AutoField用于主键,只读。...on_delete:外键关联的对象被删除时对应的动作,可取的值包括django.db.models中定义的: CASCADE:级联删除。...through:指定维持多对多关系的中间表的Django模型。 throughfields:定义了中间模型时可以指定建立多对多关系的字段。 db_table:指定维持多对多关系的中间表的表名。
模型继承 模型继承在 Django 中与普通类继承在 Python 中的工作方式几乎完全相同,但也仍应遵循本页开头的内容。这意味着其基类应该继承自 django.db.models.Model。...CommonInfo 模型不能用作普通的 Django 模型,因为它是一个抽象基类。它不会生成数据表,也没有管理器,也不能被实例化和保存。...多表继承 Django 支持的第二种模型继承方式是层次结构中的每个模型都是一个单独的模型。每个模型都指向分离的数据表,且可被独立查询和创建。...多重继承¶ 和 Python 中的继承一样,Django 模型也能继承自多个父类模型。请记住,Python 的命名规则这里也有效。...若你在祖先模型中重写了任何模型字段,Django 会抛出一个 FieldError。
IndexError异常,[0:1].get()引发DoesNotExist异常 查询集的缓存 每个查询集都包含一个缓存来最小化对数据库的访问 在新建的查询集中,缓存为空,首次对查询集求值时,会发生数据库查询,django...pk表示primary key,默认的主键是id filter(pk__lt=6) 聚合函数 使用aggregate()函数返回聚合函数的值 函数:Avg,Count,Max,Min,Sum from django.db.models...A与字段B进行比较,如果A写在了等号的左边,则B出现在等号的右边,需要通过F对象构造 list.filter(bread__gte=F('bcommet')) django支持对F()对象使用算数运算...bpub_date__lt=F('bpub_date') + timedelta(days=1)) Q对象 过滤器的方法中关键字参数查询,会合并为And进行 需要进行or查询,使用Q()对象 Q对象(django.db.models.Q...)用于封装一组关键字参数,这些关键字参数与“比较运算符”中的相同 from django.db.models import Q list.filter(Q(pk_ _lt=6)) Q对象可以使用&(and
Django中内嵌了ORM框架,不需要直接面向数据库编程,而是定义模型类,通过模型类和对象完成数据表的增删改查操作。...使用Django进行数据库开发的步骤如下: 在models.py中定义模型类 迁移 通过类和对象完成数据增删改查操作 Django模型设计 在上篇文章中我们创建了一个图书管理系统(BMSTest),并部署了一个...我们接着这个项目来介绍Django进行数据库开发过程,模型设计。 1、定义模型类 模型类定义在models.py文件中,继承自models.Model类。...根据设计,在models.py中定义模型类如下: # -*- coding:utf-8 -*- """ @Author :Hui @Desc :{模型设计模块} """ from django.db...,应用名 + 下划线 + 模型名 Django操作数据库表 数据库表建好了,看看Django如何便捷的操作。
简介 Django 中模型是真实数据的简单明确的描述,它包含了储存的数据所必要的字段和行为,在创建模型前需要先配置好数据库。...激活模型 通过配置上面 models.py 类中创建模型的代码,已经足够 Django 为我们创建数据库和相应表结构了,现在我们将 polls 应用安装到我们 TestProject 项目中。...中,所以它的点式路径是 ‘polls.apps.PollsConfig’ 保存配置并退出,然后运行 makemigrations 命令, Django 会检测你对模型文件的修改,并且把修改的部分储存为一次迁移...(迁移是 Django 对于模型定义即你的数据库结构的变化的储存形式)。...image.png 查询数据 Django 提供了多种方式来查询出数据库记录,如查询上面 Question 模型对应全部数据,某个id的数据以及通过多条件过滤得到所需要的数据。
User模型是这个框架的核心部分。他的完整的路径是在django.contrib.auth.models.User。...扩展用户模型: Django内置的User模型虽然已经足够强大了。但是有时候还是不能满足我们的需求。比如在验证用户登录的时候,他用的是用户名作为验证,而我们有时候需要通过手机号码或者邮箱来进行验证。...那么这时候我们就需要扩展用户模型了。扩展用户模型有多种方式。这里我们来一一讨论下。 1. 设置Proxy模型: 如果你对Django提供的字段,以及验证的方法都比较满意,没有什么需要改的。...示例代码如下: from django.contrib.auth.models import User from django.db import models from django.dispatch...这种方式会比较麻烦,最好是确定自己对Django比较了解才推荐使用。步骤如下: 创建模型。
本章知识点 1、Django模型关系字段介绍与使用 2、Django模型关系字段查询 知识点讲解 1、Django模型关系字段介绍与使用 业务主体间的关系 学生 和 专业 关系 一个学生对应一个专业...teacher_id from student_techer where = student_id = (Select id from student where name = “小白”)) 2、Django...模型关系字段查询 1、外键 查询学生对应的项目 这样的查询时候最简单的,学生当中外键字段对应的就是外键的完整信息,可以直接获取 项目对应的所有学生 视图部分 前端部分...2、多对多数据 老师和学生 老师对应所有学生 学生对应的所有老师 本章总结 Django模型关系字段介绍与使用 Django模型关系字段查询
类的属性 objects:是Manager类型的对象,用于与数据库进行交互 当定义模型类时没有指定管理器,则Django会为模型类提供一个名为objects的管理器 支持明确指定模型类的管理器 class...books = models.Manager() 当为模型类指定管理器后,django不再为模型类生成名为objects的默认管理器 管理器Manager 管理器是Django的模型进行数据库的查询操作的接口...,Django应用的每个模型都拥有至少一个管理器 自定义管理器类主要用于两种情况 情况一:向管理器类中添加额外的方法:见下面“创建对象”中的方式二 情况二:修改管理器返回的原始查询集:重写get_queryset...books = BookInfoManager() 创建对象 当创建对象时,django不会对数据库进行读写操作 调用save()方法才与数据库交互,将对象保存到数据库中 使用关键字参数构造模型对象很麻烦...,推荐使用下面的两种之式 说明: _init _方法已经在基类models.Model中使用,在自定义模型中无法使用, 方式一:在模型类中增加一个类方法 class BookInfo(models.Model
通常情况下,Django提供的User模型能够满足我们大部分的需求,但是有时候我们需要给User添加一些格外的功能和信息。 Django支持两种方式来扩展User模型。...代理模型 如果只是需要添加一些功能性操作,可以基于User创建一个代理模型。 关联模型 如果是需要添加格外的字段信息,则可以创建一个与User关联的模型,两者之间的关系为1对1。...,则可以Django的关联模型获取数据: >>> u = User.objects.get(username='fsmith') >>> mobile = u.profile.mobile 为了在管理后台中将...from django.contrib import admin from django.contrib.auth.admin import UserAdmin from django.contrib.auth.models...因此,当创建用户的时候,profile并不会自动创建,可以通过django.db.models.signals.post_save来创建或者更新profile模型。
定义模型 在模型中定义属性,会生成表中的字段 django根据属性的类型确定以下信息: 当前选择的数据库支持字段的类型 渲染管理表单时使用的默认html控件 在管理站点最低限度的验证 django...会为表增加自动增长的主键列,每个模型只能有一个主键列,如果使用选项设置某属性为主键列后,则django不会再生成默认的主键列 属性命名限制 不能是python的保留关键字 由于django的查询方式...,不允许使用连续的下划线 定义属性 定义属性时,需要字段类型 字段类型被定义在django.db.models.fields目录下,为了方便使用,被导入到django.db.models中 使用方式...导入from django.db import models 通过models.Field创建字段类型的对象,赋值给属性 对于重要数据都做逻辑删除,不做物理删除,实现方法是定义isDelete属性,类型为..._set bookinfo.heroinfo_set 用一访问一:对象.模型类小写 heroinfo.bookinfo 访问id:对象.属性_id heroinfo.book_id 元选项 在模型类中定义类
Django中内嵌了ORM框架,不需要直接面向数据库编程,而是定义模型类,通过模型类和对象完成数据表的增删改查操作。...使用Django进行数据库开发的步骤如下: 在models.py中定义模型类 迁移 通过类和对象完成数据增删改查操作 Django模型设计 在上篇文章中我们创建了一个图书管理系统(BMSTest),...我们接着这个项目来介绍Django进行数据库开发过程,模型设计。 1、定义模型类 模型类定义在models.py文件中,继承自models.Model类。...根据设计,在models.py中定义模型类如下: # -*- coding:utf-8 -*- """ @Author :Hui @Desc :{模型设计模块} """ from django.db...> ,应用名 + 下划线 + 模型名 Django操作数据库表 数据库表建好了,看看Django如何便捷的操作。
领取专属 10元无门槛券
手把手带您无忧上云