您的位置 首页 Python

在Django中设计组织特定模型的最佳方法?

这是一个数据库模型设计问题.假设我正在设计像Slack这样的应用程序. Slack有多个组织,每个组织内都有对象,只有该组织才能访问(例如,聊天记录,文件等).在Django中设置这些每个组织对象的最佳方法是什么?

一个简单的解决方案是将ForeignKey附加到这些对象中的每一个.像这样:

class Organization(models.Model):
    # ...

class File(models.Model):
    organization = models.ForeignKey(
        'Organization',on_delete=models.CASCADE,)
    # ...

class ChatThread(models.Model):
    organization = models.ForeignKey(
        'Organization',)
    # ...

但是如果我们这样做,我们需要在组织上放一个索引,因为有很多这样的每个组织对象,所以看起来有点浪费.

有没有更简洁的设计方法?

解决方法

我认为你的方法和它需要的一样好.在索引组织列方面,您可以使用db_index = False来禁用索引的创建.

如果要抽象组织字段并在所有组织对象上使用某些方法,则可以使用如下的抽象模型:

class Organization(models.Model):
    # ...

class OrganizationModel(models.Model):
    organization = models.ForeignKey(
        'Organization',db_index=False,)

    class Meta:
        abstract = True

class File(OrganizationModel):
    # ...

class ChatThread(OrganizationModel):
    # ...

关于作者: dawei

【声明】:金华站长网内容转载自互联网,其相关言论仅代表作者个人观点绝非权威,不代表本站立场。如您发现内容存在版权问题,请提交相关链接至邮箱:bqsm@foxmail.com,我们将及时予以处理。

热门文章