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

django 1.8 官方文档翻译:2-1-1 模型语法

如果你的模型中存在超个一个的外键,并且through_fields没有指定,将会触发一个无效的错误。 对目标模型的外键有相同的限制(上面例子中的 Person)。...Changed in Django 1.7: 在Django 1.6 及之前的版本中,中介模型禁止包含多于一个的外键。...取而代之的是,当它被用来作为一个其他model的基础类时,它将被加入那一子类中。如果抽象化基础类和它的子类有相同的项,那么将会出现error(并且Django将返回一个exception)。...查询集始终返回请求的模型 也就是说,没有办法让DJango在查询Person对象时返回MyPerson对象。Person 对象的查询集会返回相同类型的对象。...但在普通的多表继承中,子类不能继承父类的 manager ,这是因为在处理非基类字段时,父类的 manager 未必适用。 后一种情况在 管理器文档有详细介绍。

5K20

python技术面试题(十九)--腾讯

定义模型类时,我们继承了 models.Model,这个模块在 django.db中。我们在查询操作时,需要导入模型类,通过类和对象完成数据增删改查。...__del__就是一个析构函数。 7.继承,在执行析构函数时,先执行父类的,还是先执行子类的? 答:析构时,会先调用子类的析构函数,再调用父类的。...初始化子类时,会先自动调用父类的构造函数,然后调用子类的构造函数。 8.继承时,所有的方法都会被继承吗? 答:不会,比如构造函数和析构函数,它们不能被继承。...python3中range返回的是一个可迭代对象,python2中则是返回一个列表。这个题目我以为python3会报错,特意写出了上面的话。...InnoDB适合频繁修改以及安全性要求较高的应用, MyISAM适合查询为主的应用。在我们的项目中使用的是 InnoDB。 15.如果将一个列表传入函数中,在函数中修改后,全局的列表会被修改吗?

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

    django 1.8 官方文档翻译: 2-1-1 模型语法(初稿)

    model 时,要显式地定义一个外键,它与包含多对多关系的 model 相关联。...如果你没有在抽象基类中为某个关联字段定义 related_name 属性,那么默认的反向名称就是子类名称加上 ‘_set’,它能否正常工作取决于你是否在子类中定义了同名字段。...查询集只返回请求时所使用的 model (Querysets still return the model that was requested) 无论你何时查询 User 对象,Django 都不会返回...但在普通的多表继承中,子类不能继承父类的 manager ,这是因为在处理非基类字段时,父类的 manager 未必适用。在 manager documentation 有详细介绍。...如果某个特定名称 (例如,Meta) 出现在第一个基类当中,那么子类就会使用第一个基类的该特定名称。

    3.1K30

    Django之ORM字段和参数

    外键类型在ORM中用来表示外键关联关系,一般把ForeignKey字段设置在 '一对多'中'多'的一方。    ...(反向查询)时,我们会这么写: models.Classes.objects.first().student_set.all()   当我们在ForeignKey字段中添加了参数 related_name...,设置:models.SET(可执行对象) ---- db_constraint    是否在数据库中创建外键约束,默认为True。...---- through      在使用ManyToManyField字段时,Django将自动生成一张表来管理多对多的关联关系。...---- db_table                    默认创建第三张表时,数据库中表的名称。 ---- 元信息 ORM对应的类里面包含另一个Meta类,而Meta类封装了一些数据库的信息。

    2.3K60

    【Python全栈100天学习笔记】Day41 Django深入理解框架

    ,所以也能通过部门反向查询该部门的员工(从一对多关系中“一”的一方查询“多”的一方),反向查询属性默认的名字是类名小写_set(如上面例子中的emp_set),当然也可以在创建模型时通过ForeingKey...定义__str__方法。 不要将数据文件放在同一个目录中。...on_delete:外键关联的对象被删除时对应的动作,可取的值包括django.db.models中定义的: CASCADE:级联删除。...模型元数据选项 选项 说明 abstract 设置为True时模型是抽象父类 app_label 如果定义模型的应用不在INSTALLED_APPS中可以用该属性指定 db_table 模型使用的数据表名称...managed 设置为True时,Django在迁移中创建数据表并在执行flush管理命令时把表移除 order_with_respect_to 标记对象为可排序的 ordering 对象的默认排序 permissions

    2.3K30

    Django中ORM介绍和字段及其参数

    通常,一个模型(model)映射到一个数据库表, 基本情况: 每个模型都是一个Python类,它是django.db.models.Model的子类。 模型的每个属性都代表一个数据库字段。...示例   在app里面的models.py中定义一个Person模型,包含 first_name 和 last_name。...关系字段 ForeignKey   外键类型在ORM中用来表示外键关联关系,一般把ForeignKey字段设置在 '一对多'中'多'的一方。   ...to="User", to_field="id", on_delete=models.SET(func) ) db_constraint:是否在数据库中创建外键约束...verbose_name verbose_name的意思很简单,就是给你的模型类起一个更可读的名字: verbose_name = "pizza" 若未提供该选项, Django 则会用一个类名字的 munged

    2.8K80

    流畅的 Python 第二版(GPT 重译)(七)

    这两种协议共享一个重要特征,即类永远不需要声明支持某个协议,即通过继承来支持。 除了静态协议,Python 还提供了另一种在代码中定义显式接口的方式:抽象基类(ABC)。...super()函数 对于可维护的面向对象 Python 程序,一致使用super()内置函数至关重要。 当子类重写超类的方法时,通常需要调用超类的相应方法。...__setitem__调用超类上的该方法,让其插入或更新键/值对。 调用self.move_to_end以确保更新的key位于最后位置。...无论是你还是编译器提供这些参数,super()调用都会返回一个动态代理对象,该对象会在type参数的超类中找到一个方法(例如示例中的__setitem__),并将其绑定到object_or_type,这样在调用方法时就不需要显式传递接收者...当实例化时,ListView 通过object_list实例属性具有一个可迭代的对象,模板可以通过它来显示页面内容,通常是数据库查询返回多个对象的结果。

    20110

    Django ORM 多表操作

    ORM 多表操作 表模型 图书表 出版社表 作者表 作者详情表 表关系 一对一:一对一推荐建在查询频率高的一方 一对多:外键字段建在多的一方 多对多:外键字段建在查询频率多的一方,在Django第三张表不需要创建...3、一般不需要设置联级更新. 4、外键在一对多的多中设置:models.ForeignKey("关联类名", on_delete=models.CASCADE)。...6、若有模型类存在外键,创建数据时,要先创建外键关联的模型类的数据,不然创建包含外键的模型类的数据时,外键的关联模型类的数据会找不到 逆向到表模型 插入数据 ps:插入几条数据方便操作 ORM...设置外键属性的类(多的表)中,MySQL 中显示的字段名是:外键属性名_id。...正向:外键字段在哪,去从该表的角度查另外的表,就是正向 反向:从没有外键表去查另外相关联的表,就是反向 口诀: 正向查询按外键字段 反向查询按表名小写 注意: 正向:属性名 反向:小写类名加 _set

    1.8K20

    Django-Multitenant,分布式多租户数据库项目实战(PythonDjango+Postgres+Citus)

    目录 项目源码 安装 支持的 Django 版本/前提条件。 用法 模型变化 使用 mixins 更改模型 在 db 层自动化复合外键: 在哪里设置租户?...: 使用 mixins 更改模型 在您要使用库的任何文件中,只需: 所有模型都应使用 TenantModelMixin 和 django models.Model 或您的客户模型类 Ex: class...: 在 db 层自动化复合外键: 使用 TenantForeignKey 在租户相关模型之间创建外键将自动将 tenant_id 添加到引用查询(例如 product.purchases)和连接查询(例如...如果要确保在 db 层创建复合外键(带有 tenant_id),则应将 settings.py 中的数据库 ENGINE 更改为 django_multitenant.backends.postgresql...只需在身份验证时设置它,库将确保其余部分(将 tenant_id 过滤器添加到查询中)。上面的示例实现如下: 在您的设置中,您需要更新 MIDDLEWARE 设置以包含您创建的设置。

    2K10

    后端框架学习-Django

    查询谓词 类属性 + ‘__’ + 谓词 定义:做更灵活的条件查询时需要使用查询谓词 说明:每一个查询谓词都是一个独立的查询功能 __exact:等值匹配 Author.objects.filter...创建一对一数据 无外键的模型类,和之前相同 有外键的模型类: wife = Wife.objects.create(name=’王夫人’,author = author1(类属性名称绑实例...)) wife = Wife.objects.create(name=’王夫人’,author_id = 1(类属性字段绑值)) 一对一查询 正向查询:从外键查对象 反向查询:从对象查外键 调用反向属性查询到关联的一方...一对多查询 核心:正向属性(authors)和反向属性(book_set) 在多表上设置外键,关联一表。...无外键的模型类,和之前相同 有外键的模型类: 类似上面 wife = Wife.objects.create(name=’王夫人’,author = author1(类属性名称绑实例)

    9.6K40

    Django 模型继承 BaseModel

    Meta 继承 当一个抽象基类被建立,Django 将所有你在基类中申明的 Meta 内部类以属性的形式提供。若子类未定义自己的 Meta 类,它会继承父类的 Meta。...外键 或 多对多字段 使用了 related_name 或 related_query_name,你必须为该字段提供一个 独一无二 的反向名字和查询名字。...这名字看起来就像你在子类中定义的一样。...QuerySet 仍会返回请求的模型¶ 当你用 Person 对象查询时,Django 永远不会返回 MyPerson 对象。Person 对象的查询结果集总是返回对应类型。...注解 某些字段在模型内定义了额外的属性,例如 ForeignKey 定义了一个额外的属性 _id 附加在字段名上,类似的还有外键上的 related_name 和 related_query_name。

    2.1K10

    django 1.8 官方文档翻译: 2-5-6 多数据库

    该设置映射数据库别名到一个数据库连接设置的字典,这是整个Django 中引用一个数据库的方式。字典中的设置在 DATABASES 文档中有完整描述。 你可以为数据库选择任何别名。...当设置了model_name时,hints 通常通过键’model‘包含该模型的类。注意,它可能是一个历史模型,因此不会有自定的属性、方法或管理器。你应该只依赖_meta。...这个方法还可以用来决定一个给定数据库上某个模型的可用性。 注意,如果这个方法返回False,迁移将默默地不会在模型上做任何操作。这可能导致你应用某些操作之后出现损坏的外键、表多余或者缺失。...当保存在statement 2中发生时,p已经具有一个主键,Django 将尝试在新的数据库上使用该主键。...如果你使用一个路由来路由分离到不同的数据库上,这些模型定义的任何外键和多对多关联必须在单个数据库的内部。 这是因为引用完整性的原因。

    1.5K20

    37.Django1.11.6文档

    你编写完基类之后,在 Meta类中设置 abstract=True , 这个模型就不会被用来创建任何数据表。 取而代之的是,当它被用来作为一个其他model的基类时,它的字段将被加入那些子类中。...4.Meta继承 当一个抽象基类被创建的时候, Django把你在基类内部定义的 Meta 类作为一个属性使其可用。 如果子类没有声明自己的Meta类, 它将会继承父类的Meta。...')) select_related() select_related(*fields) 返回一个QuerySet,当执行它的查询时它沿着外键关系查询关联的对象的数据...它会生成一个复杂的查询并引起性能的损耗,但是在以后使用外键关系时将不需要数据库查询。...此方法将返回当前活动的用户模型 — 如果指定了自定义用户模型,否则返回User。 在定义到用户模型的外键或多对多关系时,应使用AUTH_USER_MODEL设置指定自定义模型。

    24.4K80

    Django中ORM操作

    1、无需连表查询性能低,省硬盘空间(选项不固定时用外键) 2、在modle文件里不能动态增加(选项一成不变用Django的choice) 其他字段 db_index = True 表示设置索引 unique...SQL操作 # query_set缓存机制1次数据库查询结果query_set都会对应一块缓存,再次使用该query_set时,不会发生新的SQL操作; #这样减小了频繁操作数据库给数据库带来的压力...:obj=类(属性=X,外键=obj)obj.save() classify_obj=models.Classify.objects.get(category='武侠') publish_obj...正向查找:ForeignKey在 UserInfo表中,如果从UserInfo表开始向其他的表进行查询,这个就是正向操作,反之如果从UserType表去查询其他的表这个就是反向操作。...字段就建在子表; 如果B表的1条记录也对应A表中N条记录,两表之间就是双向1对多关系,也称为多对多关系; 在orm中设置如果 A表设置了外键字段user=models.ForeignKey('UserType

    4.8K10

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

    如果你将你的视图实现为通用视图的子类,你就会发现这样能够更有效地编写你想要的代码,使用你自己的基于类或功能的视图。 在一些三方的应用中,有更多通用视图的示例,或者你可以自己按需编写。...,合并到所有超类中的上下文数据。...要在你自己想要改变上下文的类中保持这一行为,你应该确保在超类中调用了get_context_data。如果没有任意两个类尝试定义相同的键,会返回异常的结果。...然而,如果任何一个类尝试在超类持有一个键的情况下覆写它(在调用超类之后),这个类的任何子类都需要显式于超类之后设置它,如果你想要确保他们覆写了所有超类的话。...然而,通过使用queryset来定义一个过滤的对象列表,你可以更加详细 的了解哪些对象将会被显示的视图中(参见执行查询来获取更多关于查询集对象的更对信息,以及参见 基于类的视图参考来获取全部 细节)。

    1.4K40

    Django 模型中自定义Manager和模型方法

    1.自定义管理器(Manager) 在语句Book.objects.all()中,objects是一个特殊的属性,通过它来查询数据库,它就是模型的一个Manager....例如,下面的模型有两个manger--一个返回所有对象,另一个仅返回作者是Roald Dahl的书 from django.db import models #首先,定义一个Manager的子类 class...,即super(Blog, self).save(*args, **kwargs),它确保该对象仍被保存到数据库中.如果你忘记调用超类方法,那么默认的行为将不会发生,也不会发生数据库操作....Django将不时扩展内置模型方法的功能,并添加新的参数。如果您在方法定义中使用了*args, **kwargs,您将保证您的代码在添加时将自动支持这些参数。...上面的示例中,clean()引发的ValidationError异常通过一个字符串实例化,所以它将被保存在一个特殊的错误字典中,键为NON_FIELD_ERRORS.这个键用于整个模型出现的错误而不是一个特定字段穿线的错误

    2.8K20

    Django之ORM

    在Django中具体的对应方式为: 类名对应数据库中的表名 类名对应数据库中的表名 类属性对应数据库里的字段 类实例对应数据库表里的一行数据 类实例对象的属性对应这行中的字段的值 一.数据库的连接 Django...(school,on_delete=models.CASCADE) 在建表时为school添加外键约束,在数据库中的显示为 ?...除了这种方式也可以手动创建一个表,手动添加两个外键来实现多对多。...field): 对查询结果排序 reverse(): 对查询结果反向排序 distinct(): 从返回结果中剔除重复纪录 values_list(*field): 它与values()非常相似,它返回的是一个元组序列...,values返回的是一个字典序列 count(): 返回数据库中匹配查询(QuerySet)的对象数量。

    1.1K30
    领券