基本的:

models.py

####################################以下都是抽屉的代码####################################
from django.db import models
# 记录用户注册的次数
class SendMsg(models.Model):
nid = models.AutoField(primary_key=True) # 自定义id名为nid,默认id名是id【固定格式】
email = models.CharField(max_length=32, unique=True)
code = models.CharField(max_length=6)
ctime = models.DateTimeField()
times = models.IntegerField(default=0) # 新闻类型
class NewsType(models.Model):
caption = models.CharField(max_length=16) # 抽屉的用户表设计
class UserInfo(models.Model):
nid = models.AutoField(primary_key=True)
username = models.CharField(max_length=32, unique=True)
password = models.CharField(max_length=32)
email = models.CharField(max_length=32, unique=True)
ctime = models.DateTimeField() # 新闻表
class News(models.Model):
# 可以自己创建id,AutoField且primary_key = True【默认id=id】
title = models.CharField(max_length=64) # 标题
summary = models.CharField(max_length=128, null=True) # [内容,可为空简介]
url = models.URLField(null=True)
ctime = models.DateTimeField(auto_now_add=True)
# 下面2个user效果同,只是写法不同
# user = models.ForeignKey('UserInfo', on_delete=True, to_field='nid') # 跟UserInfo的nid进行关联
user = models.ForeignKey(to="UserInfo", to_field='nid', related_name='n', on_delete=True) # 跟UserInfo表关联
nt = models.ForeignKey(to='NewsType', to_field='id', related_name='tn', on_delete=True) # 关联NewsType表,关联默认的id
# 引用下面一行代码,就不需要下面的Favor表了,2个一个效果【这里采用点赞表实现,所以注释了】
# favor = models.ManyToManyField(to='UserInfo') # 默认关联的就是主键
favor_count = models.IntegerField(default=0) # 每点赞一次就增加1,同时给顶踩表添加一条数据
comment_count = models.IntegerField(default=0) # 每评论一次就增加1,同时给评论表添加一条数据 # 点赞表
class Favor(models.Model):
user = models.ForeignKey(to='UserInfo', to_field='nid', on_delete=True)
news = models.ForeignKey(to='News', to_field='id', on_delete=True) # 评论表
class Comment(models.Model):
news = models.ForeignKey(to='News', to_field='id', on_delete=True)
user = models.ForeignKey(to='UserInfo', to_field='nid', on_delete=True)
content = models.CharField(max_length=150)
ctime = models.DateTimeField(auto_now_add=True)
device = models.CharField(max_length=16, null=True) # 顶踩表:记录你顶过那个用户的哪条新闻,踩过哪个用户的哪条新闻

高级的:

这里使用many2many实现news和Useinfo的多对多的关系

我们在News里面是用来favor_count和comment_count来实现页面显示的点赞个数和评论个数的统计,后续页面有数据过来的时候,我们给favor_count和comment_count加1,且插入数据在comment和favor表中。[虽然消耗了硬盘,但是提高了速度]

models.py

####################################以下都是抽屉的代码####################################
from django.db import models
# 记录用户注册的次数
class SendMsg(models.Model):
nid = models.AutoField(primary_key=True) # 自定义id名为nid,默认id名是id【固定格式】
email = models.CharField(max_length=32, unique=True)
code = models.CharField(max_length=6)
ctime = models.DateTimeField()
times = models.IntegerField(default=0) # 新闻类型
class NewsType(models.Model):
caption = models.CharField(max_length=16) # 抽屉的用户表设计
class UserInfo(models.Model):
nid = models.AutoField(primary_key=True)
username = models.CharField(max_length=32, unique=True)
password = models.CharField(max_length=32)
email = models.CharField(max_length=32, unique=True)
ctime = models.DateTimeField() # 新闻表
class News(models.Model):
# 可以自己创建id,AutoField且primary_key = True【默认id=id】
title = models.CharField(max_length=64) # 标题
summary = models.CharField(max_length=128, null=True) # [内容,可为空简介]
url = models.URLField(null=True)
ctime = models.DateTimeField(auto_now_add=True)
# 下面2个user效果同,只是写法不同
# user = models.ForeignKey('UserInfo', on_delete=True, to_field='nid') # 跟UserInfo的nid进行关联
user = models.ForeignKey(to="UserInfo", to_field='nid', related_name='n', on_delete=True) # 跟UserInfo表关联
nt = models.ForeignKey(to='NewsType', to_field='id', related_name='tn', on_delete=True) # 关联NewsType表,关联默认的id
# 引用下面一行代码,就不需要下面的Favor表了,2个一个效果【不采用点赞表Favor】
favor = models.ManyToManyField(to='UserInfo') # 默认关联的就是主键
favor_count = models.IntegerField(default=0) # 每点赞一次就增加1,同时给顶踩表添加一条数据
comment_count = models.IntegerField(default=0) # 每评论一次就增加1,同时给评论表添加一条数据 # 点赞表【这里采用manyTomany实现userInfo和News单独关系,所以注释了】
# class Favor(models.Model):
# user = models.ForeignKey(to='UserInfo', to_field='nid', on_delete=True)
# news = models.ForeignKey(to='News', to_field='id', on_delete=True) # 评论表
class Comment(models.Model):
news = models.ForeignKey(to='News', to_field='id', on_delete=True)
user = models.ForeignKey(to='UserInfo', to_field='nid', on_delete=True)
content = models.CharField(max_length=150)
ctime = models.DateTimeField(auto_now_add=True)
device = models.CharField(max_length=16, null=True) # 顶踩表:记录你顶过那个用户的哪条新闻,踩过哪个用户的哪条新闻

终极版:提升速度,增加功能

models.py

####################################以下都是抽屉的代码####################################
from django.db import models
# 记录用户注册的次数
class SendMsg(models.Model):
nid = models.AutoField(primary_key=True) # 自定义id名为nid,默认id名是id【固定格式】
email = models.CharField(max_length=32, unique=True)
code = models.CharField(max_length=6)
ctime = models.DateTimeField()
times = models.IntegerField(default=0) # 新闻类型
class NewsType(models.Model):
caption = models.CharField(max_length=16) # 抽屉的用户表设计
class UserInfo(models.Model):
nid = models.AutoField(primary_key=True)
username = models.CharField(max_length=32, unique=True)
password = models.CharField(max_length=32)
email = models.CharField(max_length=32, unique=True)
ctime = models.DateTimeField() # 新闻表
class News(models.Model):
# 可以自己创建id,AutoField且primary_key = True【默认id=id】
title = models.CharField(max_length=64) # 标题
summary = models.CharField(max_length=128, null=True) # [内容,可为空简介]
url = models.URLField(null=True)
ctime = models.DateTimeField(auto_now_add=True)
# 下面2个user效果同,只是写法不同
# user = models.ForeignKey('UserInfo', on_delete=True, to_field='nid') # 跟UserInfo的nid进行关联
user = models.ForeignKey(to="UserInfo", to_field='nid', related_name='n', on_delete=True) # 跟UserInfo表关联
# nt = models.ForeignKey(to='NewsType', to_field='id', related_name='tn', on_delete=True) # 关联NewsType表,关联默认的id
# 因为内容固定,所以这里直接采用列表的形式了
news_type_choices = [
(1, '42区'),
(2, '段子'),
(3, '图片'),
(4, '挨踢1024'),
(5, '你问我答'),
]
# DjangoAdmin里面会渲染为一个下拉框,这里需要我们自己去写下拉框了
nt = models.IntegerField(choices=news_type_choices)
# 引用下面一行代码,就不需要下面的Favor表了,2个一个效果
favor = models.ManyToManyField(to='UserInfo') # 默认关联的就是主键
favor_count = models.IntegerField(default=0) # 每点赞一次就增加1,同时给顶踩表添加一条数据
comment_count = models.IntegerField(default=0) # 每评论一次就增加1,同时给评论表添加一条数据 # 点赞表 【这里我们采用many2many实现多对多的关系,此表暂时不用】
# class Favor(models.Model):
# user = models.ForeignKey(to='UserInfo', to_field='nid', on_delete=True)
# news = models.ForeignKey(to='News', to_field='id', on_delete=True) # 评论表
class Comment(models.Model):
news = models.ForeignKey(to='News', to_field='id', on_delete=True)
user = models.ForeignKey(to='UserInfo', to_field='nid', on_delete=True)
content = models.CharField(max_length=150)
ctime = models.DateTimeField(auto_now_add=True)
device = models.CharField(max_length=16, null=True)
# 这里要求父评论只能是数字且是Comment里面的自增ID
# 要求也能实现反向查找【此时可认为是2个Comment表,但需要添加releat_name,否则就易混乱】
parent_comment = models.ForeignKey(to="Comment", null=True, on_delete=True, related_name='pc') # 顶踩表:记录你顶过那个用户的哪条新闻,踩过哪个用户的哪条新闻

Python学习---抽屉框架分析[数据库设计分析]180313的更多相关文章

  1. Python学习---抽屉框架分析[小评论分析]0315

    注: 此处的小评论涉及数据库操作 初级小评论代码 settings.py INSTALLED_APPS = [ ... 'app01', # 注册app ] STATICFILES_DIRS = (o ...

  2. Python学习---抽屉框架分析[ORM操作]180314

    Django ORM操作     1. 字段操作         class User(model.Model);             u=字段        用处:            1 . ...

  3. Python学习---抽屉框架分析[点赞功能/文件上传分析]0317

    点赞功能分析 前台传递过来新闻id[new_id]和session[session内有用户ID和用户之间的信息]到后台 后台News数据库内用户和新闻是多对多的关系,查看第三张表中的内容,判读用户Id ...

  4. Python学习---抽屉框架分析[点赞功能分析]

    实际上就是多了一个隐藏的span标签,内容是+1,配合setInterval实现的动态效果 settings.py INSTALLED_APPS = [ ... 'app01', # 注册app ] ...

  5. python学习-- Django根据现有数据库,自动生成models模型文件

    Django引入外部数据库还是比较方便的,步骤如下 : 创建一个项目,修改seting文件,在setting里面设置你要连接的数据库类型和连接名称,地址之类,和创建新项目的时候一致 运行下面代码可以自 ...

  6. [TimLinux] Python学习内容框架

    以下内容主体来自<Python学习手册第四版>,大致整理出的方向 1. 第一部分:使用入门 介绍Python语法之前,先对Python的的各个方面进行一个比较宽广的介绍,包含对Python ...

  7. [Python] 学习笔记之MySQL数据库操作

    1 Python标准数据库接口DB-API介绍 Python标准数据库接口为 Python DB-API,它为开发人员提供了数据库应用编程接口.Python DB-API支持很多种的数据库,你可以选择 ...

  8. Python学习(十七)—— 数据库(二)

    转载自http://www.cnblogs.com/linhaifeng/articles/7356064.html 一. 数据库管理软件的由来 基于我们之前所学,数据要想永久保存,都是保存于文件中, ...

  9. Python学习——web框架

    对于所有的Web应用,本质上其实就是一个socket服务端,用户的浏览器其实就是一个socket客户端. WSGI(Web Server Gateway Interface)是一种规范,它定义了使用p ...

随机推荐

  1. 在Linux上创建webrev(cont)[基于svn]

    在前文中,基于git介绍了webrev工具.实际上,webrev工具还支持hg和svn.最近的工作中不可避免地要使用svn,故在此总结一下如何基于svn在Linux上创建webrev.顺便吐个槽,没有 ...

  2. 基础语言知识JAVA

    1. 总结: JAVA比较重要的博客: http://www.runoob.com/java/java-tutorial.html     (JAVA教程) http://blog.csdn.net/ ...

  3. 实现一个简单的"jQuery"

    本次博客记录一个简单的"jQuey"的实现方式,来加深对jQuery的理解: 代码: <!DOCTYPE html> <html> <head> ...

  4. WPF 小知识点001

    1.DataGrid 单选事件 <DataGrid MinHeight="150"                  AutoGenerateColumns="Fa ...

  5. C#基础笔记(第十二天)

    1.复习里氏转换:1).子类可以赋值给父类(如果有一个方法需要一个父类作为参数,我们可以传第一个子类对象)2).如果父类中装的是子类对象,则可以将这个父类强转为子类对象 is和as判断转换成功失败 P ...

  6. 五、curator recipes之选举主节点Leader Latch

    简介 在分布式计算中,主节点选举是为了把某个进程作为主节点来控制其它节点的过程.在选举结束之前,我们不知道哪个节点会成为主节点.curator对于主节点选举有两种实现方式,本文示例演示Latch的实现 ...

  7. 八、window搭建spark + IDEA开发环境

    本文将简单搭建一个spark的开发环境,如下: 1)操作系统:window os 2)IDEA开发工具以及scala插件(IDEA和插件版本要对应): 2-1)IDEA2018.2.1:https:/ ...

  8. 折半插入排序-ACM题

    第一种实现方式:(本人一开始对cin的使用不是很熟悉,看了一些人得博客详解后才有了第一种方式的实现,自己都被惊讶到了so easy:题目在下面) // // main.cpp // BinaryIns ...

  9. C#学习笔记-模板方法模式

    题目:同学摘抄老师给的试卷并给出自己的对应的答案. 实现: static void Main(string[] args) { Console.WriteLine("学生甲抄的试卷:&quo ...

  10. textarea的maxlength属性兼容解决方案

    IE10版本的textarea才支持maxlength属性:低版本的IE都不兼容,实际上低版本的IE的市场存在率还是很高的: 所以还是很有必要来整合一套解决方案的: Jquery版本 $(functi ...