python - 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)
体裁可以有很多故事,每个部分可以有很多章节和类似的模式
问题:
有没有更好的设计模型可供我使用?
可以将它们划分为不同的应用程序,或者为每个流派有一个应用程序,或者将流派作为模型包含在内。
解决方案
我会提出这种设计。
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 会自动添加id
with AutoField
。如果要使用自定义 PrimaryKey,则必须自己制作。我建议你可以在Story.stry
. 添加blank=False, null=False
不是必需的。这是 Django 的标准行为。
如果要在 yoru index-App 中使用模型,可以在需要的地方导入。
可以将它们划分为不同的应用程序,或者为每个流派有一个应用程序,或者将流派作为模型包含在内。
在我看来,我会在你的模型中添加一种“流派标签”Story
并将它们放在一起。
推荐阅读
- java - Flink:从行字段中提取数组
- java - 有没有办法按行拆分 RDD?
- javascript - JavaScript onclick 多 div 更改类列表添加/删除返回到后面?
- android - 在回收器视图项中动态完成时视图不隐藏
- angular - 在 Angular 中找不到带有参数 Id 的 Url
- command-line - 如何使用 REST API 从命令行触发 TeamCity 构建?
- xamarin.forms - 如何将 kenburnseffect 应用到跨平台 xamarin imageview 中?
- azure - Azure 逻辑应用的 ARM 模板 - SQL 创建触发器
- python - 如何将训练过程的所有信息保存在 tf 中?
- c# - Intellisense 无法处理项目之间的共享资源文件(Visual Studio 2015)