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. Java中main方法里面的参数一定要是String []args吗?2. javascript - 想做一个canvas的触摸画板,但屏幕会在画的时候滚来滚去,如何阻止?3. 系统重装后,恢复mysql5.5?4. docker绑定了nginx端口 外部访问不到5. javascript - node.js中stat() access() open() readFile()都能判断文件是否存在?6. css3 - CSS优先级问题7. mysql - sql 左连接结果union右连接结果,导致重复性计算怎么解决?8. javascript - js 多维数组的问题9. css - 如何讓圖片像雲一樣的行為?10. html5 - 目前 公司App 嵌入H5页面 做个 手机支付功能 没有做过 所以 请求各位有经验的 给个思路

网公网安备