5

我正在继承现有模型(完全来自另一个应用程序)并希望我的模型拥有自己的数据库表。原始表的相同克隆/副本,而不仅仅是带有指向“父”表中存储的数据的指针的表。

这是我的模型:

class A (models.Model):
    name = models.CharField('name')

class MyA (A):
    class Meta:
        db_table = 'My_A'

这是我的数据库表:

CREATE TABLE A
(
  id serial NOT NULL,
  "name" character varying(50) NOT NULL,
  ...
)

CREATE TABLE My_A
(
  A_ptr_id integer NOT NULL,
  ...
)

这就是我想要的:

CREATE TABLE A
(
  id serial NOT NULL,
  "name" character varying(50) NOT NULL,
  ...
)

CREATE TABLE My_A
(
  id serial NOT NULL,
  "name" character varying(50) NOT NULL,
  ...
)

编辑:我最终复制粘贴了第 3 方模型

4

3 回答 3

4

如果我对您的理解正确,您可以创建一个没有自己的表的抽象基类。然后,您可以从那里创建多个从具有自己的表的基类继承的类。

class ABase(models.Model):
    name = models.CharField('name')
    class Meta:
        abstract = True

class A(ABase):
    class Meta:
        db_table = 'A'

class MyA(ABase):
    class Meta:
        db_table = 'My_A'

Django 2.2 文档 - 抽象基类

于 2019-06-12T01:36:08.223 回答
0

新方法(如果您坚持分离数据):创建模型 MyA 而不从 A 继承,并创建另一个模型 MergeA,该模型为 My 和 A 创建显式通用外键。但这肯定需要相当多的额外编码。

于 2012-08-22T09:13:34.503 回答
-1

当您继承 Django 模型时,它总是会生成与父模型的隐含 1-1 关系。Django 只会为您继承的模型生成字段。总的来说,这对我来说完全有意义。但是对于您的用例来说很麻烦。由于我们正在讨论 Django 核心功能,因此可能很难解决。您可以尝试将您的第 3 方模型作为代理模型复制并粘贴到您的代码中并从那里继承。

更新:但是为什么要将数据分成不同的表?最终目标是什么?

于 2012-08-22T07:33:14.523 回答