- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
许多有经验的开发人员建议不要使用 Django multi-table inheritance因为它的性能不佳:
Django gotcha: concrete inheritance通过 Jacob Kaplan-Moss ,Django 的核心贡献者。
In nearly every case, abstract inheritance is a better approach for the long term. I’ve seen more than few sites crushed under the load introduced by concrete inheritance, so I’d strongly suggest that Django users approach any use of concrete inheritance with a large dose of skepticism.
Two Scoops of Django通过 Daniel Greenfield ( @pydanny )
Multi-table inheritance, sometimes called “concrete inheritance,” is considered by the authors and many other developers to be a bad thing. We strongly recommend against using it.
At all costs, everyone should avoid multi-table inheritance since it adds both confusion and substantial overhead. Instead of multi-table inheritance, use explicit OneToOneFields and ForeignKeys between models so you can control when joins are traversed.
但是没有多表继承,我不能轻易
Reference base model in another model (必须使用 GenericForeignKey 或反向依赖);
Get all instances of base model .
(欢迎补充)
那么Django中这种继承有什么问题呢?为什么显式 OneToOneFields 更好?
JOIN 对性能的影响有多大?是否有任何基准可以显示性能差异?
难道 select_related()
不允许我们控制何时调用 JOIN 吗?
我已将具体示例移至 separate question由于这个变得过于宽泛,因此添加了一个使用多表继承的原因列表。
最佳答案
首先,继承并没有自然转化为关系数据库架构(好吧,我知道,Oracle 类型对象和其他一些 RDBMS 支持继承,但 django 不利用此功能)
在这一点上,注意 django 为子类生成新表并写入 很多 left joins
从这个“子表” 中检索数据。和 left joins are not your friends .在高性能场景中,如游戏后端或其他场景,您应该避免它并使用一些工件(如空值、OneToOne 或外键)“手动”解决继承。在 OneToOne
场景,可以直接调用相关表,也可以只在需要时调用。
...但是...
“在我看来 (TGW)” 当模型继承出现在您的 universe of discourse 时,您应该在您的企业项目中包含模型继承。 。我这样做了,由于这个功能,我为我的客户节省了大量的开发时间。此外,代码变得干净优雅,这意味着易于维护(请注意,此类项目不会有数百个或每秒请求)
逐题
问:Django中这种继承有什么问题?
A:很多表,很多左连接。
问:为什么显式 OneToOneFields 更好?
A:你可以直接访问相关模型,无需左连接。
问:有没有说明性的例子(基准)?
A:没有可比性。
问:select_related() 是否允许我们控制何时调用 JOIN?
A: django 加入需要的表。
问:当我需要在另一个模型中引用基类时,多表继承的替代方案是什么?
答:作废。 OneToOne 关系和大量代码行。这取决于应用需求。
问:在这种情况下,GenericForeignKeys 是否更好?
答:不适合我。
问:如果我需要 OneToOneField 作为基础模型怎么办?
答:写吧。这没有问题。例如,您可以扩展 User 模型,也可以为某些用户提供 OneToOne 到 User 基础模型。
结论
您应该了解在没有模型继承的情况下编写和维护代码的成本,以及支持模型继承应用程序并采取相应行动的硬件成本。
开个玩笑:你可以用汇编代码写,而且运行速度会更快。
引用 Trey Hunner :
Your time is usually much more expensive than your CPU's time.
关于django - 我应该以任何方式避免 Django 中的多表(具体)继承吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/23466577/
我是 Robert,我在使用 JavaScript 时遇到了一些问题。 我得到了一个 (这是隐藏的)。我唯一想问你的是:我想检查日期是否在 中已通过。如果通过了我想改变CSS中容器的背景颜色。不幸的
所以我的问题是我想要求输入使用扫描仪的信息,但它根本不打印出来。当它显示跳过的扫描仪的值时,Scanner CheeseType = new Scanner(System.in);,我得到 null。
Fe_Order_Items fe_order_items_id fe_order_specification_id fe_users_id fe_menu_items_id fe_order_ite
人们普遍提到 - “Celery 是一个基于分布式消息传递的异步任务队列/作业队列”。虽然我知道如何使用 Celery 工作人员等。但内心深处我不明白分布式消息传递的真正重要性和意义以及任务队列在其中
我试图理解下面的代码,但有一些我以前从未见过的东西,那就是:“\&\&” 这是代码: int main() { fork() \&\& (fork() || fork()); exit(EXIT_SU
您好,我是论坛新手。 我有很多使用 python 的经验,但没有使用 tkinter 的经验。 这是我的代码: from tkinter import * def Done(): celEn
在 C# 中,假设我们有一个通用类和一个具体类 [Serializable] public class GenericUser { ... [Serializable] public class Co
我尝试使用的库有一个通用抽象类,其中有两个实现该基础的子类。我想编写一个类,它将根据构造函数参数的参数类型自动创建其中一个子级的实例。 基类没有默认构造函数 基类的构造函数也需要其他通用类的实例 代码
我是 Angular 的新手,我一直在尝试了解它的工作原理。我正在制作一个简单的应用程序,其中有人可以通过简单的 html 界面添加用户并使用 SQLite 将其存储在数据库中,然后他们可以编辑或删除
我想创建一个用于存储数据的对象,限制读/写访问。 例如: OBJ obj1; OBJ obj2; // DataOBJ has 2 methods : read() and write() DataO
注入(inject)/隔离密封在 dll 中且不实现接口(interface)的类的首选方法是什么? 我们使用 Ninject。 假设我们有一个类“Server”,我们想要注入(inject)/隔离“
在花费了至少 10 个小时的时间浏览在线资源、视频和教程之后,我有两个关于将我的 Android 应用程序与 mySQL 数据库连接的问题。 保存文件 1) 所有教程都将 php 文件保存在 C/WA
许多有经验的开发人员建议不要使用 Django multi-table inheritance因为它的性能不佳: Django gotcha: concrete inheritance通过 Jacob
我知道我冒着挨揍的风险,但我觉得我在这件事上要绕圈子。为了让模型可用于多个项目,我们已将模型移出到一个单独的项目(一个 DLL)中,作为一系列要实现的接口(interface)。我们的界面上有这一行:
按照目前的情况,这个问题不适合我们的问答形式。我们希望答案得到事实、引用或专业知识的支持,但这个问题可能会引发辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visit the
我遇到了一个特定 mac 的问题,它没有显示我正确构建的某个网站。我测试过的所有其他 mac 和 pc 都能正确显示网站,但是在所有浏览器中这个特定的 mac 显示不正确就像提到的那样,这在其他每台计
给定这段代码 public override void Serialize(BaseContentObject obj) { string file = ObjectDataStoreFold
我已经搜索了网络和我的服务器,但我无法找到我网站的 php.ini。我的网站出现以下错误。 Class 'finfo' not found Details G:\inetpub\wwwroot\lan
SQL 爱好者: 我正在尝试通过玩以下用例来挖掘我一些生疏的 sql 技能: 假设我们有一家有线电视公司,并且有跟踪的数据库表: 电视节目, 观看我们节目的客户,以及 观看事件(特定客户观看特定节目的
我正在设计一个使用 HTML5 网络组件(HTML 导入、影子 DOM、模板和自定义 HTML 元素)的网络应用程序,这些组件是通过普通 JavaScript(无框架)实现的。 Web 应用程序相当简
我是一名优秀的程序员,十分优秀!