|
# 表设计
一个项目中最最最重要的不是业务逻辑的书写
而是前期的表设计,只有将表设计好了,后续的功能书写才会一帆风顺
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='站点样式') # 存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)
# 文章内容有很多 一般情况下用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) # 有些评论就是跟评论
|
|
|