首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

Django模型model

前言 根据前几篇文章的分享已经了解djangoWeb开发一般步骤为: 创建虚拟环境 安装django 创建项目 创建应用 在model.py中创建模型类 定义视图 配置url 创建模板 1....: 根据对象的类型生成数据库表结构 将对象、列表的操作,转换为sql语句 将sql查询到的结果转换为对象、列表 Django中的模型包含存储数据的字段和约束,对应着数据库中唯一的表 ORM.png 2....会为表增加自动增长的主键列,每个模型只能有一个主键列,如果使用选项设置某属性为主键列后,则django不会再生成默认的主键列 属性命名限制 不能是python的保留关键字 由于django的查询方式,不允许使用连续的下划线...模型类的查询 查询集表示从数据库中获取的对象集合 查询集可以含有零个、一个或多个过滤器 过滤器基于所给的参数限制查询的结果 从Sql的角度,查询集和select语句等价,过滤器像where和limit子句...创建查询集不会带来任何数据库的访问,直到调用数据时,才会访问数据库 何时对查询集求值:迭代,序列化,与if合用 返回查询集的方法,称为过滤器,管理器对象方法有all()、filter()、exclude

15310
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    Django—模型

    ,如果使用选项设置某属性为主键列后django不会再创建自动增长的主键列。...4.查询集 查询集表示从数据库中获取的对象集合,在管理器上调用某些过滤器方法会返回查询集,查询集可以含有零个、一个或多个过滤器。...缓存:使用同一个查询集,第一次使用时会发生数据库的查询,然后把结果缓存下来,再次使用这个查询集时会使用缓存的数据。 查询集的缓存 每个查询集都包含一个缓存来最小化对数据库的访问。...在新建的查询集中,缓存为空,首次对查询集求值时,会发生数据库查询,django会将查询的结果存在查询集的缓存中,并返回请求的结果,接下来对查询集求值将重用缓存中的结果。...情况二:经过存储后,可以重用查询集,第二次使用缓存中的数据。

    6.1K21

    django_2

    要求 修改数据库 Django shell 数据级联(一对多) 元信息 定义字段 模型过滤 创建对象4种方式 查询集 过滤器 获取单个对象 字段查询 时间 聚合函数 跨关系查询 F对象 Q对象..., 如果使用选项设置某属性为主键列后, 则django不会再生成默认的主键列 ·属性命名限制 ·遵循标识符规则 ·由于django的查询方式,不允许使用连续的下划线 库.../缓存集 查询集的缓存:每个查询集都包含一个缓存,来最小化对数据库的访问 在新建的查询集中,缓存首次为空,第一次对查询集求值,会发生数据缓存,django会将查询出来的数据做 一个缓存,并返回查询结果...,以后的查询直接使用查询集的缓存。...会为表增加自动增长的主键列,每个模型只能有一个主键列, 如果使用选项设置某属性为主键列后, 则django不会再生成默认的主键列 ·属性命名限制 ·遵循标识符规则 ·由于django

    3.6K30

    django 1.8 官方文档翻译: 2-6-4 数据库访问优化

    网站:http://python.usyiyi.cn/django/index.html 数据库访问优化 Django的数据库层提供了很多方法来帮助开发者充分的利用他们的数据库。...理解查询集 理解查询集(QuerySets) 是通过简单的代码获取较好性能至关重要的一步。特别是: 理解查询集计算 要避免性能问题,理解以下几点非常重要: QuerySets是延迟的。...一次性检索你需要的任何东西 在不同的位置多次访问数据库,一次获取一个数据集,通常来说不如在一次查询中获取它们更高效。如果你在一个循环中执行查询,这尤其重要。...对于在模板代码中替换模型对象,这样会非常有用 —— 只要字典中带有的属性和模板中使用的一致,就没问题。...直接使用外键的值 如果你仅仅需要外键当中的一个值,要使用对象上你已经取得的外键的值,而不是获取整个关联对象再得到它的主键。

    1.1K30

    Django 模型查询2.3

    简介 查询集表示从数据库中获取的对象集合 查询集可以含有零个、一个或多个过滤器 过滤器基于所给的参数限制查询的结果 从Sql的角度,查询集和select语句等价,过滤器像where和limit子句 接下来主要讨论如下知识点...查询集 字段查询:比较运算符,F对象,Q对象 查询集 在管理器上调用过滤器方法会返回查询集 查询集经过过滤器筛选后返回新的查询集,因此可以写成链式过滤 惰性执行:创建查询集不会带来任何数据库的访问...():返回第一个对象 last():返回最后一个对象 exists():判断查询集中是否有数据,如果有则返回True 限制查询集 查询集返回列表,可以使用下标的方式进行限制,等同于sql中的limit和...,[0:1].get()引发DoesNotExist异常 查询集的缓存 每个查询集都包含一个缓存来最小化对数据库的访问 在新建的查询集中,缓存为空,首次对查询集求值时,会发生数据库查询,django会将查询的结果存在查询集的缓存中...过滤器的方法中关键字参数查询,会合并为And进行 需要进行or查询,使用Q()对象 Q对象(django.db.models.Q)用于封装一组关键字参数,这些关键字参数与“比较运算符”中的相同 from

    2.4K20

    django 1.8 官方文档翻译: 3-4-2 内建显示视图

    对象的通用视图 TemplateView确实很有用,但是当你需要 呈现你数据库中的内容时Django的通用视图才真的会脱颖而出。...编写“友好的”模板上下文 你可能已经注意到了,我们在publisher列表的例子中把所有的publisher对象 放到 object_list 变量中。...然而,通过使用queryset来定义一个过滤的对象列表,你可以更加详细 的了解哪些对象将会被显示的视图中(参见执行查询来获取更多关于查询集对象的更对信息,以及参见 基于类的视图参考来获取全部 细节)。...如果我们不这么做,通过视图会使用和 “vanilla” 对象列表名称一样的模板,这可 能不是我们想要的。 另外需要注意,这并不是处理特定出版商的图书的非常优雅的方法。...pk - 这个名字是DetailView用来查找主键的值的默认名称,其中主键用于过滤查询集。

    1.4K40

    Python全栈开发之Django基础

    () 查询集 查询集表示从数据库中查询到的对象集合 返回查询集的过滤器 all():返回所有数据 filter(): 返回满足条件的数据 exclude(): 返回不满足条件的数据 order_by()...): 返回当前查询结果的总条数 aggregate(): 聚合,返回一个字典 判断一个查询集中是否有数据 两个特性 惰性 创建查询集不会访问数据库,直到调用数据时,才会访问数据库 缓存 使用同一个结果集...,第一次使用会触发查询数据库,然后将结果缓存下载,再次使用直接调用缓存 限制结果集 可以对结果集进行切片操作,等同于数据库中的分页操作,但是不支持负数 list = BookInfo.objects.all...由一对多的访问语法 一端的对象.多端的类名_set b = BookInfo.objects.get(id=1) b.HeroInfo_set.all() 由多对一的访问语法 多端的模型对象.多端模型类的类关系字段...使用load标签引入模块 {%load filters%} 模板继承 父模板 如果发现在多个模板中某些内容相同,那就应该把这段内容定义到父模板中 标签block:用于在父模板中预留区域,留给子模板填充差异性的内容

    3.8K20

    django 1.8 官方文档翻译: 2-3-1 模型实例参考

    如果你手工赋值一个自增主键的值,请确保不要使用一个已经存在的主键值!如果你使用数据库中已经存在的主键值创建一个新的对象,Django 将假设你正在修改这个已存在的记录而不是创建一个新的记录。...如果对象的主键属性没有设置或者UPDATE 没有更新任何记录,Django 将执行INSERT。 现在应该明白了,当保存一个新的对象时,如果不能保证主键的值没有使用,你应该注意不要显式指定主键值。...Django 在许多地方都使用unicode(obj)(或者相关的函数 str(obj))。最明显的是在Django 的Admin 站点显示一个对象和在模板中插入对象的值的时候。...最明显的是在Django 的Admin 站点显示一个对象和在模板中插入对象的值的时候。 所以,你应该始终让__str__() 方法返回模型的一个友好的、人类可读的形式。...代码和模板中对get_absolute_url() 的调用应该可以直接使用而不用做进一步处理。

    1.9K10

    Django MVC概述和开发流程

    在Django中,ORM在开发者和数据库之间建立了一个中间层,把对数据库的CURD转换成了Python中的对象实体的操作,这样既屏蔽了不同数据库之间的差异,而且又使得开发者可以使用面向对象的特性来操作数据库...在多类记录中访问一类直接使用st2.school即可,而在一类记录中访问多类可以使用 # 一类.多类名小写_set.all() 返回的是多类实例对象组成的列表 sc3.studentinfo_set.all...的HttpResponse对象,而实际中需要用到html、css等渲染和js的加载,所以需要使用模板文件来解决这个问题。...{# 注释 #} 表示注释,不会出现在最终渲染出来的html文件中; {{ 变量名 }} 表示在模板中使用变量,变量可以是从视图函数中传递过来的,也可以是在模板中定义的; {% 代码段 %} 表示在模板中编写的代码段...render函数第一个参数为request对象,第二个参数为模板文件路径,第三个参数为上下文(字典,向模板文件传递的数据) from django.shortcuts import render from

    1.9K10

    django 1.8 官方文档翻译: 2-2-1 执行查询

    一般来说,对 QuerySet 切片会返回新的 QuerySet – 这个过程中不会对运行查询。不过也有例外,如果你在切片时使用了 “step” 参数,查询集就会被求值,就在数据库中运行查询。...举个例子,使用下面这个这个查询集返回前十个对象中的偶数次对象,就会运行数据库查询: >>> Entry.objects.all()[:10:2] 要检索单独的对象,而非列表 (比如 SELECT foo...针对这两种情况,Django 用一种很方便的方式来使用 filter() 和 exclude()。对于包含在同一个 filter() 中的筛选条件,查询集要同时满足所有筛选条件。...')) 主键查询的简捷方式 为使用方便考虑,Django 用 pk 代表主键”primary key”。...为某个查询指定某个值的时候,你可以使用一个类实例,也可以使用对象的主键值。

    4.4K20

    Django内置的通用类视图CBV及示例

    "/login/" TemplateView 显示Django HTML template 一般网站中使用模板显示的页 ListView 显示对象列表 文章列表页 DetailView 显示对象详情 文章详细页...表示对象列表的一个页面. 执行这个视图的时候,self.object_list将包含视图正在操作的对象列表(通常是一个查询集,但不是必须)....属性: model: 视图要显示的模型 queryset: 表示对象的一个查询集.queryset的值优先于model的值. template_name: 字符串表示的模板名称. context_object_name...None):返回该视图要显示的单个对象.如果提供了queryset,该queryset将作为对象的查询源,否则,将使用get_queryset().get_object()从视图的所有参数中查找pk_url_kwarg...为True时,get_object()将使用主键和slug执行查询.

    3.2K10

    django模型

    也可以使用一条语句创建并保存一个对象,使用create()方法 查询对象 通过模型中的管理器构造一个查询集,来从你的数据库中获取对象。 查询集(queryset)表示从数据库中取出来的对象的集合。...查询集是惰性执行的 —— 创建查询集不会带来任何数据库的访问。...当你确实需要结果时, 查询集 通过访问数据库来求值 获取一个单一的对象——get() filter() 始终给你一个查询集,即使只有一个对象满足查询条件 —— 这种情况下,查询集将 只包含一个元素。...这个异常是正在查询的模型类的一个属性 —— 所以在上面的代码中, 如果没有主键为1 的Entry 对象,Django 将引发一个Entry.DoesNotExist。...如果您在某些情 况下使用查询集的结果,当您最初获取数据时不知道是否需要这些特定字段,可以告诉 Django不要从数据库中检索它们。

    3.1K20

    Django相关知识点回顾

    Flask中request请求对象的属性 Django中request请求对象的属性 说明 args GET 查询字符串参数 form POST 请求体中的表单数据 data body 请求体中的原始...13.2.2.2for循环 b) Django模板中的for循环和jinja2模板中for循环对比。...|过滤器(参数...)}} b) Django中模板过滤器的使用 {{ 模板变量|过滤器:参数 }} 注意:Django过滤器 :之后只能接收一个参数 13.3步骤 13.3.1数据库连接配置 flask...all 无 查询模型类对应表格中的所有数据 QuerySet(查询集) get 查询条件 查询满足条件一条且只能有一条数据 模型类对象,查不到会报错DoesNotExist filter 查询条件 返回满足条件的所有数据...查询结果的缓存 使用同一个查询集时,只有在第一次使用查询集时会进行数据库的查询操作,然后Django框架就会把查询的结果存起来,下一次再使用这个查询集时,使用的Django之前存储的结果。

    10K51

    Django来敲门~第一部分【9.使用Django内置视图处理对象简化开发】

    后面会详细讲解Django每一部分的使用方式和API了 本节内容 内置视图处理对象的定义 内置视图处理对象的使用 源代码分析 1....,不够~所以提供了常规的一些页面视图对象对页面模板和模板中要展示的数据进行了封装处理。...视图对象的使用 经过上述的改造,我们可以看到视图处理函数已经变得非常的简洁,但是存在这样一个问题,IndexView处理类中的数据,我们可以看懂是通过get_queryset()函数进行查询的,然后自动复制给变量...DetailView和ResultView中的要查询的数据,同样也是通过主键编号进行查询的,默认的变量名称是pk,所以在路由中要进行如下的修改配置,才可以正常使用 改造polls/urls.py路由模块...我们可以在源代码中,看到各种操作的一些信息,官方注释用于使用对象数据来渲染详细信息页面的视图对象,继承的父类中,也定义了各种属性字段用于控制单个对象数据的展示操作 以上两个视图类,都间接继承了View

    90730

    Django内置的通用类视图及实例

    表示对象列表的一个页面. 执行这个视图的时候,self.object_list将包含视图正在操作的对象列表(通常是一个查询集,但不是必须)....方法: get_queryset():获取此视图的对象列表.必须是可迭代或者可以使查询集.默认返回queryset属性.可以通过重写该方法实现动态过滤.让这种方式能够工作的关键点,在于当类视图被调用时...属性: model: 视图要显示的模型 queryset: 表示对象的一个查询集.queryset的值优先于model的值. template_name: 字符串表示的模板名称. context_object_name...None):返回该视图要显示的单个对象.如果提供了queryset,该queryset将作为对象的查询源,否则,将使用get_queryset().get_object()从视图的所有参数中查找pk_url_kwarg...为True时,get_object()将使用主键和slug执行查询.

    2.9K40

    Django之QuerySet详解

    exclude() 排除满足条件的对象 annotate() 使用聚合函数 order_by() 对查询集进行排序 reverse() 反向排序 distinct() 对查询集去重...tzinfo参数定义在截取之前将数据时间转换到的时区。 11. none() 调用none()将创建一个不返回任何对象的查询集,并且在访问结果时不会执行任何查询。...下面是一个标准的查询: # 访问数据库。 e = Entry.objects.get(id=5) # 再次访问数据库以得到关联的Blog对象。...当最初获取数据时不知道是否需要这些特定字段的情况下,如果正在使用查询集的结果,可以告诉Django不要从数据库中检索它们。...对于返回大量只需要访问一次的对象的QuerySet,这可以带来更好的性能,显著减少内存使用。 请注意,在已经提交了的iterator()上使用QuerySet会强制它再次提交数据库操作,进行重复查询。

    2.4K20
    领券