ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

基于Django框架开发BBS项目

2020-06-10 15:53:47  阅读:435  来源: 互联网

标签:name 框架 ForeignKey models True Django null BBS verbose


一、表设计

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="Article")    
is_up    BooleanField()

7.文章评论表

记录哪个用户给哪篇文章写了哪些评论内容
user    ForeignKey(to="User")    
article    ForeignKey(to="Article")
content    CharField()
comment_time    DateField()
# 自关联
parent    ForeignKey(to="Comment",null=True)    
# ORM专门提供的自关联写法    
parent    ForeignKey(to="self",null=True)
7.评论表

根评论和子评论
to='self'

 

 modles.py

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):
    site_name = models.CharField(verbose_name='站点名称',max_length=32)
    site_title = models.CharField(verbose_name='站点标题',max_length=32)
    # 简单模拟 带你认识样式内部原理的操作
    site_theme = models.CharField(verbose_name='站点样式',max_length=64)  # 存css/js的文件路径


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)
    # 文章内容有很多 一般情况下都是使用TextField
    content = models.TextField(verbose_name='文章内容')
    create_time = models.DateField(auto_now_add=True)

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

    # 外键字段
    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(verbose_name='评论时间',auto_now_add=True)
    # 自关联
    parent = models.ForeignKey(to='self',null=True)  # 有些评论就是根评论

 

二、注册功能

注册功能用到的技术点有以下

  • forms组件

  • 用户头像前端实时展示

  • ajax

 

三、登录功能 

登录功能的技术点有以下

  • 实现图片验证码

  • ajax

标签:name,框架,ForeignKey,models,True,Django,null,BBS,verbose
来源: https://www.cnblogs.com/heirenxilou/p/13072011.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有