mysql - 问答网站的架构数据库设计?
问题描述
初学django,准备练手仿一个 简化的segfmentfault网站。 现在有几个疑问。
class Answer(models.Model): id = models.IntegerField(primary_key=True) user_id = models.PositiveIntegerField(verbose_name=’用户ID’) vote = models.IntegerField(verbose_name=’得票’) data = models.TextField(verbose_name=’数据’, max_length=4096 * 10) post_time = models.DateTimeField(verbose_name=’创建时间’, default=datetime.datetime.now) mod_time = models.DateTimeField(verbose_name=’修改时间’) class Meta:verbose_name = ’用户回答’class Question(models.Model): Q_CHOICES = ((’0’, u’Show’),(’1’, u’Hide’),(’2’, u’Closed’), ) BOOL_CHOICES = ((’0’, u’False’),(’1’, u’True’), ) id = models.IntegerField(primary_key=True) name = models.CharField(verbose_name=’名称’, max_length=128) status = models.CharField(verbose_name=’状态’, max_length=1, choices=Q_CHOICES) type = models.SmallIntegerField(verbose_name=’类别’) post_time = models.DateTimeField(verbose_name=’创建时间’, default=datetime.datetime.now) mod_time = models.DateTimeField(verbose_name=’修改时间’) vote = models.IntegerField(verbose_name=’得票’) data = models.TextField(verbose_name=’数据’, max_length=4096 * 10) user_id = models.PositiveIntegerField(verbose_name=’用户ID’) view_num = models.PositiveIntegerField(verbose_name=’浏览数’) class Meta:verbose_name = ’问题列表’
现在数据库这块,都推荐反范式的数据库设计。 这种问答网站适合用外键吗?
我这张表还缺什么字段,我个人想到的只有这些, 求大神大概分析下。
问题表
答案表
评论表
问题解答
回答1:规模上说,数据量大的不适合用外键,小的可以用;用途上安全性、可靠性很重要的就要用外键,否则可以不用。具体情况具体分析
具体缺啥字段由业务来决定
相关文章:
1. 关于docker下的nginx压力测试2. docker内创建jenkins访问另一个容器下的服务器问题3. 为什么我ping不通我的docker容器呢???4. debian - docker依赖的aufs-tools源码哪里可以找到啊?5. javascript - 我的站点貌似被别人克隆了, google 搜索特定文章,除了域名不一样,其他的都一样,如何解决?6. docker镜像push报错7. nignx - docker内nginx 80端口被占用8. dockerfile - 为什么docker容器启动不了?9. html5 - node静态资源服务器设置了Cache-Control,但浏览器从来不走30410. docker安装后出现Cannot connect to the Docker daemon.

网公网安备