首页 > 解决方案 > Djnago 模型设计数据库

问题描述

我是 Django 项目的新手,想知道设计模型的最佳实践是什么。我正在创建一个小项目,该项目将以类别和子类别的方式收集故事。我将其标记为 Django,因为我还想验证 app 的范围。

应用:索引、流派

设计:

Index

Genre
|-- Story
    |--Section
         |-- Chapters
             |--Paragraph
                 |-- title
                 |-- text
                 |-- highlights 

流派模型.py

class Story(models.Model):
    stry = models.CharField(max_length=256,unique=True)
    id =models.AutoField(primary_key=True)
    def __str__(self):
        return self.stry
class Section(models.Model):
    stry = models.ForeignKey(Story,on_delete=models.CASCADE)
    name = models.CharField(max_length=256)
    desc=models.TextField()
    id =models.AutoField(primary_key=True)
    slug = models.CharField(max_length=240, null=True, blank=False)
    created_at = models.DateTimeField(auto_now_add=True, null=False)
    updated_at = models.DateTimeField(auto_now=True, null=False)    

class Chapter(models.Model):    
    sec = models.ForeignKey(Section,on_delete=models.CASCADE)
    name = models.CharField(max_length=256)
    desc=models.TextField()
    id =models.AutoField(primary_key=True)
    slug = models.CharField(max_length=240, null=True, blank=False)
    created_at = models.DateTimeField(auto_now_add=True, null=False)
    updated_at = models.DateTimeField(auto_now=True, null=False)
class Paragraph(models.Model):
    chap = models.ForeignKey(Chapter,on_delete=models.CASCADE)
    title = models.CharField(max_length=120, null=True, blank=False)
    subtitle = models.CharField(max_length=180, null=True, blank=False)
    slug = models.CharField(max_length=240, null=True, blank=False)
    body = models.TextField()
    created_at = models.DateTimeField(auto_now_add=True, null=False)
    updated_at = models.DateTimeField(auto_now=True, null=False)
    

体裁可以有很多故事,每个部分可以有很多章节和类似的模式

问题:

标签: pythondjangodjango-modelsdatabase-designmodel

解决方案


我会提出这种设计。

class DateTimeSlug(models.Model):
    created_at = models.DateTimeField(auto_now_add=True)
    updated_at = models.DateTimeField(auto_now=True)
    slug = models.CharField(max_length=240)
    
    class Meta:
        abstract = True

    
class NameDesc(models.Model):
    name = models.CharField(max_length=256)
    desc=models.TextField()

    class Meta:
        abstract = True

class Story(models.Model):
    stry = models.CharField(max_length=256, primary_key=True)

    def __str__(self):
        return self.stry
    
class Section(DateTimeSlug, NameDesc):
    stry = models.ForeignKey(Story,on_delete=models.CASCADE, related_name='sections')
     
class Chapter(DateTimeSlug, NameDesc):    
    sec = models.ForeignKey(Section,on_delete=models.CASCADE, related_name='chapters')

class Paragraph(DateTimeSlug):
    chap = models.ForeignKey(Chapter, on_delete=models.CASCADE, related_name='paragraphs')
    title = models.CharField(max_length=120)
    subtitle = models.CharField(max_length=180)
    body = models.TextField()

id = models.AutoField(primary_key=True)没有必要,因为 Django 会自动添加idwith AutoField。如果要使用自定义 PrimaryKey,则必须自己制作。我建议你可以在Story.stry. 添加blank=False, null=False不是必需的。这是 Django 的标准行为。

如果要在 yoru index-App 中使用模型,可以在需要的地方导入。

可以将它们划分为不同的应用程序,或者为每个流派有一个应用程序,或者将流派作为模型包含在内。

在我看来,我会在你的模型中添加一种“流派标签”Story并将它们放在一起。


推荐阅读