【问题标题】:How to create a Django MPTT model with multiple trees如何创建具有多棵树的 Django MPTT 模型
【发布时间】:2026-02-10 15:15:01
【问题描述】:

我正在尝试创建一个结构,其中一个模型名为“Company”,另一个模型名为“FSLI”。 FSLI 是一种 MPTT 模型。 每个 FSLI 都必须映射到一个公司。每个公司可以有多个 FSLI。 以下是我的 FSLI 模型代码:

class Fsli(MPTTModel):

    name = models.CharField(max_length=255)
    parent = TreeForeignKey('self', on_delete=models.CASCADE, null=True, blank=True, related_name='parent_child')
    company = models.ForeignKey("Company", on_delete=models.CASCADE, related_name="company_fsli")

    ASSET = "asset"
    LIABILITY = "liability"
    EQUITY = "equity"
    INCOME = "income"
    EXPENSE = "expense"
    FSLI_TYPES = (
        (ASSET, "Asset"),
        (LIABILITY, "Liability"),
        (EQUITY, "Equity"),
        (INCOME, "Income"),
        (EXPENSE, "Expense"),
    )

    fsli_type = models.CharField(max_length=9, choices=FSLI_TYPES, default=ASSET)
    remap_locked = models.BooleanField(default=False)
    rename_locked = models.BooleanField(default=False)
    delete_locked = models.BooleanField(default=False)
    unmapped_cat =  models.BooleanField(default=False)
    statement = None
    if fsli_type == 'income' or fsli_type == 'expense':
        statement = 'pl'
    else:
        statement = 'bs'

    def __str__(self):
        return f"{self.name} - {self.fsli_type} - {self.company}"

我希望 Django-MPTT 根据其“公司”字段为 FSLI 对象创建单独的树结构。例如,公司“foo”的一棵 FSLI 对象树和公司“bar”的另一棵树 我该怎么做?

另外,与简单的单树结构相比,我以后在使用这种方法访问和更新树时会遇到任何其他问题/限制吗?

【问题讨论】:

  • 您必须控制每个公司只有从根节点下降的节点,而其他任何公司都不使用该节点。如果您在公司中为Fsli 模型使用ManyToManyfield,可能会更清晰、更可控,可能使用其自己的专用through 模型,其中包含适当的检查甚至例程。
  • 我明白了。每个公司一个根节点。

标签: django django-models django-mptt


【解决方案1】:

这是基于 Risadinha 的评论

我为每个公司创建了一个根节点。每个公司的所有节点都从各自的根节点下降。

【讨论】: