设为首页 收藏本站
查看: 562|回复: 0

[经验分享] 构建BBS项目的表设计与如何建表

[复制链接]
累计签到:514 天
连续签到:9 天
发表于 2022-10-19 00:22:52 | 显示全部楼层 |阅读模式
# 表设计
一个项目中最最最重要的不是业务逻辑的书写
而是前期的表设计,只有将表设计好了,后续的功能书写才会一帆风顺

bbs表设计
[1、用户表]
    继承AbstractUser
    扩展
        phone  电话号码
        avatar  用户头像
        create_time 创建时间
    外键字段
        一对一个人站点表
[2、个人站点表]
    site_name 站点名称
    site_title 站点标题
    site_theme 站点样式

[3、文章标签表]
    name 标签名
    外键字段
        一对多个人站点
[4、文章分类表]
    name 分类名
    外键字段
        一对多个人站点
[5、文章表]
    title 文章标题
    desc 文章简介
    content 文章内容
    create_time 发布时间
    外键字段
        一对多个人站点
        多对多文章标签
        一对多文章分类

数据库字段设计优化(虽然下属的三个字段可以从其他表里面跨表查询计算得出,但是频繁跨表效率低)
    up_num      点赞数
    down_num    点踩数
    comment_num 评论数

[6、点赞点踩表]
    记录那个用户给那片文章点了赞点了踩
        user        ForeignKey(to='User')
        article     ForeignKey(to='User')
        is_up       booleanField()
        1       1       1
        1       2       1
        1       3       0
        2       1       1
        
[7、文章评论表]
    记录那个用户给哪些文章写了哪些评论内容
        user            ForeignKey(to='User')
        article         ForeignKey(to='User')
        content         CharField()
        create_time     DateField()
        # 自关联
        parent          ForeignKey(to='Comment',null=True)
        # ORM专门提供的自关联的写法
        parent          ForeignKey(to='self',null=True)
跟评论子评论的概念
    跟评论就是直接评论当前发布的内容
    子评论是评论别人的评论
        1.PHP是世界上最牛逼的语言
            1.1 python才是最牛逼
            1.2 java 才是
    跟评论与子评论是一对多的关系

[通过分析总结出来可以分成7但是比较关键的是要明白每个字段的存储类型和外键关系设计,因为一切的业务逻辑都是围绕着表和表之间的增删改查,所以在前期表单设计体现出尤为重要的地位
=================================================================================================================================================================================现在开始在django项目见表了
from django.db import models

# Create your models here.
"""
先写普通字段
再写外键字段
"""
from django.contrib.auth.models import AbstractUser


class UserInfo(AbstractUser):
    phone=models.BigIntegerField(verbose_name='手机号',null=True)
    # 头像
    avatar = models.FileField(upload_to='avatar/',default='avatar/default.png',verbose_name='用户头像')
    """
    avatar字段传文件对象 该文件会自动存储到avatar文件下 然后avatar字段只保存文件路径avatar/default.png
    """
    create_time = models.DateField(auto_now_add=True)

    # 与站点是一对一
    blog = models.OneToOneField(to='Blog',null=True)


class Blog(models.Model):
    state_name = models.CharField(max_length=32,verbose_name='站点名称')
    state_title = models.CharField(max_length=32,verbose_name='站点标题')
    state_theme = models.CharField(max_length=64,verbose_name='站点样式') # cssjs的文件路径


class Category(models.Model):
    name = models.CharField(verbose_name='文章发类',max_length=32)
    blog= models.ForeignKey(to='Blog',null=True)

class Tag(models.Model):
    name = models.CharField(verbose_name='文章标签',max_length=32)
    blog= models.ForeignKey(to='Blog',null=True)

class Article(models.Model):
    title = models.CharField(verbose_name='文章标题',max_length=64)
    desc = models.CharField(verbose_name='文章简介',max_length=255)
    # 文章内容有很多 一般情况下用text
    content = models.TextField(verbose_name='文章内容')
    create_time = models.DateField(auto_now_add=True)

    # 数据库字段设计优化
    up_num = models.BigIntegerField(default=0,verbose_name='点赞数')
    down_num = models.BigIntegerField(default=0,verbose_name='点踩数')
    comment_num = models.BigIntegerField(default=0,verbose_name='评论数')

    # 外键字段
    blog= models.ForeignKey(to='Blog',null=True)
    category = models.ForeignKey(to='Category',null=True)
    tags = models.ManyToManyField(to='Tag',
                                  through='Article2Tag',
                                  through_fields=('article','tag')
                                  )

class Article2Tag(models.Model):
    article= models.ForeignKey(to='Article')
    tag= models.ForeignKey(to='Tag')


class UpAndDown(models.Model):
    user = models.ForeignKey(to='UserInfo')
    article = models.ForeignKey(to='Article')
    is_up = models.BooleanField() # 传布尔值 存0/1

class Comment(models.Model):
    user = models.ForeignKey(to='UserInfo')
    article = models.ForeignKey(to='Article')
    content = models.CharField(verbose_name='评论内容',max_length=255)
    comment_time= models.DateTimeField(auto_now_add=True,verbose_name='评论时间') # 这个是记录修改时间,DateField记录创建时间
    # 自关联
    parent = models.ForeignKey(to='self',null=True) # 有些评论就是跟评论




运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-1002576-1-1.html 上篇帖子: Django之forms组件 下篇帖子: 如何通过Django操作cookie操作
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表