首页
学习
活动
专区
圈层
工具
发布

Django模型model

定义模型类 在模型中定义属性,会生成数据库表中的字段 django根据属性的类型确定以下信息: 当前选择的数据库支持字段的类型 渲染管理表单时使用的默认html控件 在管理站点最低限度的验证 django...定义模型属性 定义属性时,需要字段类型 字段类型被定义在django.db.models.fields目录下,为了方便使用,被导入到django.db.models中 使用方式 导入from django.db...实例表示的日期 参数DateField.auto_now:每次保存对象时,自动设置该字段为当前时间,用于"最后一次修改"的时间戳,它总是使用当前日期,默认为false 参数DateField.auto_now_add...:当对象第一次被创建时自动设置当前时间,用于创建的时间戳,它总是使用当前日期,默认为false 该字段默认对应的表单控件是一个TextInput....当创建对象时,django不会对数据库进行读写操作 在管理器的方法中,可以通过self.model来得到它所属的模型类 调用save()方法才与数据库交互,将对象保存到数据库中 使用关键字参数构造模型对象很麻烦

1.1K10

django 1.8 官方文档翻译: 2-5-1 管理器 (初稿)

使用管理器访问关联对象 默认情况下,在访问相关对象时(例如choice.poll),Django 并不使用相关对象的默认管理器,而是使用一个”朴素”管理器类的实例来访问。...带queryset_only 属性,并且值为False的方法总是被复制。 带 queryset_only 属性,并且值为True 的方法不会被复制。...在整个这一节中,我们将那种由 Django 为你创建的管理器称之为 “自动管理器”,既有因为没有管理器而被 Django 自动添加的默认管理器, 也包括在访问关联模型时使用的临时管理器。...如果你重写了 get_queryset() 方法并且过滤掉了一些行数据,Django 将返回不正确的结果。不要这么做!...在 get_queryset()方法中过滤掉数据,会使得它所在的管理器不适于用做自动管理器。

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

    Django DjangoFilterBackend django-filter

    djangorestframework==3.8.2 django-filter==2.0.0 #2 需求 获取某些数据时,需要按某些字段过滤 过滤时,有些的字段是 “跨表” 的字段,该如何处理 过滤时...,有些字段是 “区间” 字段(比如时间),该如何处理 过滤时,有些字段是 “跨表” 后的 “区间” 字段,又该如何处理 #3 起步 #3.1 新建一个Django项目 . ├── app │ ├──...#5 跨表过滤 需求:根据老师的名字过滤 class getUserListFilter(django_filters.rest_framework.FilterSet): teaname =...注意 : 在url的参数中,原来我们在filters.py中定义的变量是 “RegDate”,到了url中变成了 “RegDate_after” 和 “RegDate_before”,这是框架给我设定好的区间变量...的数值,如果使用queryset.filter(xxx).filter(xxx),那么返回的结果是所有过滤的交集,如果每个自定义函数都返回自己过滤的数据(例如,models.Student.objects.filter

    1.8K20

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

    对象的通用视图 TemplateView确实很有用,但是当你需要 呈现你数据库中的内容时Django的通用视图才真的会脱颖而出。...当你处理 一个object或者queryset时,Django能够使用你定义对象显示用的自述名(verbose name,或者复数的自述名,对于对象列表)来填充上下文(context)。...总是个好主意。...然而,通过使用queryset来定义一个过滤的对象列表,你可以更加详细 的了解哪些对象将会被显示的视图中(参见执行查询来获取更多关于查询集对象的更对信息,以及参见 基于类的视图参考来获取全部 细节)。...相当方便的是, ListView 有一个get_queryset() 方法来供我们重写。在之前,它只是返回一个queryset属性值,但是现在我们可以添加更多的逻辑。

    1.9K40

    【Django】聚合在Django的详细解析以及运用在企业级项目里的方法

    第一种方法是从整个QuerySet生成摘要值。例如,想计算所有在售图书的平均价格。Django的查询语法提供了一种描述所有藏书的方法。 传递给聚合()的参数描述了要计算的聚合值。...如果要指定聚合值的名称,可以在指定聚合子句时提供指定的名称。...但是,有时要聚合的值属于所查询模型的关联模型。 在聚合函数中指定聚合字段时,Django允许您在筛选相关字段时使用相同的双下划线符号。Django将处理需要检索和聚合相关值的任何表连接。...(num_authors=Count('authors')) annotate()和filter()子句的顺序¶ 在开发涉及annotate()和filter()子句的复杂查询时,请特别注意应用于QuerySet...过滤器优先于注释,因此过滤器限制了计算注释时要考虑的对象。 第一个查询请求具有至少一本得分大于3的书的平均得分。第二个查询仅请求得分超过3的作者书的平均分数。

    2.4K40

    【愚公系列】2022年01月 Python教学课程 42-Django框架之ORM中查询详解

    答:使用F对象,被定义在django.db.models中。 语法如下: F(属性名) 例:查询阅读量大于等于评论量的图书。...(readcount__gt=20).filter(id__lt=3) QuerySet []> 如果需要实现逻辑或or的查询,需要使用Q()对象结合|运算符,Q对象被义在...聚合函数包括:Avg平均,Count数量,Max最大,Min最小,Sum求和,被定义在django.db.models中。 例:查询图书的总阅读量。...PeopleInfo: 王语嫣>, <PeopleInfo 6.查询集QuerySet 1 概念 Django的ORM中存在查询集的概念。...查询集,也称查询结果集、QuerySet,表示从数据库中获取的对象集合。 当调用如下过滤器方法时,Django会返回查询集(而不是简单的列表): all():返回所有数据。

    2.2K40

    django_2

    # flask(BaseQuery) tornado(Query) django(QuerySet) django中的filter结果 QuerySet []...根据属性的类型确定以下信息 ·当前选择的数据库支持字段的类型 ·渲染管理表单时使用的默认html控件 ·在管理站点最低限度的验证 ·django会为表增加自动增长的主键列,每个模型只能有一个主键列...(用的多) ·当对象第一次被创建时自动设置当前时间, 用于创建的时间戳,它总是使用当前日期,默认为false ·说明 ·该字段默认对应的表单控件是一个TextInput...'> 得到的是查询集合,queryset没有save属性,获取所有数据 概述 ·django根据属性的类型确定以下信息 ·当前选择的数据库支持字段的类型 ·渲染管理表单时使用的默认...·属性命名限制 ·遵循标识符规则 ·由于django的查询方式,不允许使用连续的下划线 库 ·定义属性时,需要字段类型,字段类型被定义在 django.db.models.fields

    4.4K30

    python测试开发django-169.过滤器django-filter 入门使用

    前言 在管理后台查询的时候,经常有需要查询包含某个内容,按时间段查询,或者商品价格大于多少,小于多少各种查询条件。 django-filter 过滤器专门解决这种查询的问题。...假设我们有一个Product模型,我们想让我们的用户过滤他们在列表页面上看到的产品。...Django 表单,当我们遍历 时,FilterSet.qs我们会得到结果查询集中的对象。..., name, value): return queryset.filter(**{ name: value, }) 声明过滤器 声明式语法在创建过滤器时为您提供了最大的灵活性...您可以使用 Django 的__语法遍历“关系路径”来过滤相关模型上的字段。 例如:manufacturer__name。 lookup_expr: 过滤时使用的字段查找。

    2.6K20

    drf框架中所有视图及用法

    0909自我总结 drf框架中所有视图及用法 一.drf框架中的所有视图类 from django.views import View from rest_framework import views,...generics, mixins, viewsets 最基础:django自带的views类 drf框架中最基础的视图类:views.APIView drf框架中工具视图:generics GenericAPIView...自带的views进行相关方法的分装 二.viewsets视图集 ViewSetMixin:视图集工具 - 重写as_view - 将 请求方式 映射到视图类中的 指定方法 我们在路由中 类名.as_view...data:用于返序列化传参 many:获取多个序列化对象 instance:如果有后面save执行更新方法,没有执行创建方法 partial:为True可以进行局部字段修改,默认为False为所有字段修改...使用这些方法的重要前提必须要 queryset serializer_class 如果我们要使用get_object()必须前端传给我们一个pk 四.mixins使用 mixins是在generics

    2K30

    Django-官网查询部分翻译(1.11版本文档)-QuerySet-字段查找-06

    django(ORM)中,数据库与 python 对象的映射关系十分形象,一个表模型类(class)即代表一张表,实例化出一个对象即代表一条数据记录 创建一个对象(一条数据记录) 在 django...你可以给 QuerySet 叠加许多许多过滤条件,但是 django 并不会去执行他们,直到 QuerySet 被 evaluated (检查,评估?...() 来更高效的获取数据条数 用 list() 把 QuerySet 强制转换成 list 时 强转成 bool 类型或者 作为 if 条件 时 如果 QuerySet 的查询结果至少有一个(数据对象...queryset]) # 重用上一次查询出来的结果(cache) When QuerySets are not cached 不会保存 cache 缓存的情况 QuerySet 也不总是会缓存他的查询结果...=False) 过滤字段 .none() 创建空的 QuerySet 调用 .none() 方法会创建一个空的 QuerySet ,里面不包含任何数据对象,并且在取值时也不会执行任何数据库操作(是 EmptyQuerySet

    3.2K20

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

    它可以含有零个、一个或者多个过滤器,过滤器根据所给的参数限制查询结果的范围。在sql的角度,QuerySet和SELECT命令等价,过滤器是像WHERE和LIMIT一样的限制子句。...pub_date__gte=datetime(2005, 1, 30) ... ) 最开始的QuerySet包含数据库中的所有对象,之后增加一个过滤器去掉一部分,在之后又是另外一个过滤器。...你可以一直添加过滤器,在这个过程中,Django 不会执行任何数据库查询,除非 QuerySet 被执行....再次运行 QuerySet 时就会重用这些缓存结果。 要牢住上面所说的缓存行为,否则在使用 QuerySet 时可能会给你造成不小的麻烦。...在 Django 删除对象时,会模仿 SQL 约束 ON DELETE CASCADE 的行为,换句话说,删除一个对象时也会删除与它相关联的外键对象。

    5K20

    django 1.8 官方文档翻译: 2-5-4 聚合 (初稿)

    在聚合函式中指定聚合字段时,Django 允许你使用同样的 双下划线 表示关联关系,然后 Django 在就会处理要读取的关联表,并得到关联对象的聚合。...作用于普通模型字段的任何 filter()(或 exclude()) 都会对聚合涉及的对象进行限制。 使用annotate() 子句时,过滤器有限制注解对象的作用。...name__startswith="Django").annotate(num_authors=Count('authors')) 使用aggregate()子句时,过滤器有限制聚合对象的作用。...但是第一个查询的注解包含其该出版商发行的所有图书的总数;而第二个查询的注解只包含出版过好书的出版商的所发行的图书总数。 在第一个查询中,注解在过滤器之前,所以过滤器对注解没有影响。...在第二个查询中,过滤器在注解之前,所以,在计算注解值时,过滤器就限制了参与运算的对象的范围。 order_by() 注解可以用来做为排序项。

    2.1K30

    Django学习笔记之Django ORM Aggregation聚合详解

    )).filter(num_authors__gt=1) 编写一个包含annotate()和filter()从句的复杂查询时,要特别注意作用于QuerySet的从句的顺序顺序的不同,产生的意义也不同:...但是第一个查询的注解包含其该出版商发行的所有图书的总数;而第二个查询的注解只包含出版过好书的出版商的所发行的好书(评分大于3分)总数。在第一个查询中,注解在过滤器之前,所以过滤器对注解没有影响。...在第二个查询中,过滤器在注解之前,所以,在计算注解值时,过滤器就限制了参与运算的对象的范围 order_by() 可以根据聚合值进行排序 >>> Book.objects.annotate(num_authors...就不是在原始的 QuerySet 返回结果中对每个对象中添加注解,而是根据定义在 values() 从句中的字段组合对先结果进行唯一的分组,再根据每个分组算出注解值,这个注解值是根据分组中所有的成员计算而得的...对象,然后在每个分组中得到id值的总数。

    1.3K20

    Django REST Framework-如何使用过滤器

    Django REST Framework (DRF) 是一个开源的 Web 框架,它建立在 Django 上,可以帮助你轻松地构建 RESTful API。...DRF 提供了很多有用的功能,其中之一就是过滤器(filters)。过滤器是一种机制,它可以让你在获取资源时对它们进行过滤。在 DRF 中,你可以使用内置的过滤器或者编写自定义的过滤器。...例如,你可以在视图的类定义中添加如下代码:from rest_framework import filtersclass MyView(viewsets.ModelViewSet): queryset...编写自定义的过滤器可以让你更好地控制过滤逻辑,并且可以使用任何 Django QuerySet 方法来处理过滤器。...另外,我们还展示了如何编写自定义的过滤器,以便你可以更好地控制过滤逻辑,并使用任何 Django QuerySet 方法来处理过滤器。

    2.6K40

    Django 聚合与查询集API实现侧边栏

    2.django提供了两种生成聚合的方法 1)从整个查询集生成统计值,主要用法:aggregate(*args, **kwargs) aggregate()是QuerySet 的一个终止子句,也就是说...发现aggregate 和 annotate用法的区别了吗,再次举例如下(在聚合函数中指定聚合字段时,Django 允许你使用同样的 双下划线 表示关联关系,): >>> from django.db.models...__startswith="Django").annotate(num_authors=Count('authors')) # 使用annotate() 子句时,过滤器有限制注解对象的作用。...')) # 使用aggregate()子句时,过滤器有限制聚合对象的作用。...,但只有作者名称和average_rating 注解会返回在输出结果中 4.查询集(QuerySet)API 查询 本质上,可以创建、过滤、切片和传递查询集而不用真实操作数据库。

    1.8K20

    Django MVT之M

    在Django MVC概述和开发流程中已经讲解了Django的MVT开发流程,本文重点对MVT中的模型(Model)进行重点讲解。 配置MySQL数据库 确保已经安装了操作mysql的包。...1)参数auto_now表示每次保存对象时,自动设置该字段为当前时间,用于”最后一次修改”的时间戳,它总是使用当前日期,默认为false。...2) 参数auto_now_add表示当对象第一次被创建时自动设置当前时间,用于创建的时间戳,它总是使用当前日期,默认为false。...查询集(QuerySet对象) 调用all, filter, exclude, order_by这些函数会返回一个查询集(QuerySet对象),查询集有以下特性: 惰性查询:只有在实际使用查询集中的数据的时候才会发生对数据库的真正查询...F对象支持算术运算 # 查询女生人数大于男生人数 * 2的班级 QuerySet对象 Grades.objects.filter(girlnum_gt=F('boynum') * 2) Q对象 用于查询时指定条件之间的逻辑关系

    1.3K10

    翻译了Django1.4数据库访问优化部分

    使用with模板标签 在模板中使用QuerySet缓存,需要使用with标签 使用iterator() 获取大量数据时 news_list = News.objects.filter(title__contains...news_list = News.objects.filter(title__contains=u'和谐').exclude(status=1) 使用 F() object query expressions 在同一模型中使用不同字段进行对比过滤...不要获取你不需要的数据 使用 QuerySet.values() 和 values_list() 当只需要一个字段的值,返回list或者dict时,使用 values news_list = News.objects.values...{{ emails|length }} 的使用将调用 QuerySet.__len__(),数据已在缓存 for 循环的email数据已经在缓存中了。...批量插入 用 django.db.models.query.QuerySet.bulk_create() 批量创建对象,减少SQL查询的 数量。

    73010
    领券