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. android - 安卓activity无法填充屏幕2. javascript - SuperSlide.js火狐不兼容怎么回事呢3. python 计算两个时间相差的分钟数,超过一天时计算不对4. 一个走错路的23岁傻小子的提问5. java - 创建maven项目失败了 求解决方法6. android spinner改变下拉弹出的位置7. python - django 里自定义的 login 方法,如何使用 login_required()8. java - 为什么hibernate查询表集报错?9. node.js - 函数getByName()中如何使得co执行完后才return10. java - 安卓电视盒子取得了root权限但是不能安装第三方应用,请问该怎么办?
