Python学习---抽屉框架分析[数据库设计分析]180313
基本的:
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的更多相关文章
- Python学习---抽屉框架分析[小评论分析]0315
注: 此处的小评论涉及数据库操作 初级小评论代码 settings.py INSTALLED_APPS = [ ... 'app01', # 注册app ] STATICFILES_DIRS = (o ...
- Python学习---抽屉框架分析[ORM操作]180314
Django ORM操作 1. 字段操作 class User(model.Model); u=字段 用处: 1 . ...
- Python学习---抽屉框架分析[点赞功能/文件上传分析]0317
点赞功能分析 前台传递过来新闻id[new_id]和session[session内有用户ID和用户之间的信息]到后台 后台News数据库内用户和新闻是多对多的关系,查看第三张表中的内容,判读用户Id ...
- Python学习---抽屉框架分析[点赞功能分析]
实际上就是多了一个隐藏的span标签,内容是+1,配合setInterval实现的动态效果 settings.py INSTALLED_APPS = [ ... 'app01', # 注册app ] ...
- python学习-- Django根据现有数据库,自动生成models模型文件
Django引入外部数据库还是比较方便的,步骤如下 : 创建一个项目,修改seting文件,在setting里面设置你要连接的数据库类型和连接名称,地址之类,和创建新项目的时候一致 运行下面代码可以自 ...
- [TimLinux] Python学习内容框架
以下内容主体来自<Python学习手册第四版>,大致整理出的方向 1. 第一部分:使用入门 介绍Python语法之前,先对Python的的各个方面进行一个比较宽广的介绍,包含对Python ...
- [Python] 学习笔记之MySQL数据库操作
1 Python标准数据库接口DB-API介绍 Python标准数据库接口为 Python DB-API,它为开发人员提供了数据库应用编程接口.Python DB-API支持很多种的数据库,你可以选择 ...
- Python学习(十七)—— 数据库(二)
转载自http://www.cnblogs.com/linhaifeng/articles/7356064.html 一. 数据库管理软件的由来 基于我们之前所学,数据要想永久保存,都是保存于文件中, ...
- Python学习——web框架
对于所有的Web应用,本质上其实就是一个socket服务端,用户的浏览器其实就是一个socket客户端. WSGI(Web Server Gateway Interface)是一种规范,它定义了使用p ...
随机推荐
- 【分步详解】两个有序数组中的中位数和Top K问题
(这也是一道leetcode的经典题目:<LeetCode>解题笔记:004. Median of Two Sorted Arrays[H] 问题介绍 这是个超级超级经典的分治算法!!这个 ...
- vue测试安装和配置
npm install --save-dev @vue/test-utils mocha mocha-webpack npm install --save-dev jsdom jsdom-global ...
- linux下wc功能的简单实现
1.代码来源:自己编写 2.运行环境:linux终端 3.编程语言:c/c++语言 4.bug:未发现 5.当前功能:可以统计字符的字符数.行数.单词数 6.使用方法:wc -l 文件名-->统 ...
- PHP中return,exit,die的区别
参考:die(),exit(),return的区别 1.die() 是遇到错误才停止,停止程序运行,输出内容(是程序级别的) 2.exit,exit():是一个函数 是停止程序运行,前者不输出内容:后 ...
- WCF-异步调用和两种客户端形式
当发布一个服务端之后,客户端可以通过服务端的元数据,用VS2010添加服务引用的方式生成对应的代码.并且可以选择生成相应的异步操作. WCF实现代码,Add操作延时5秒后再返回结果. [Service ...
- ssh 和 scp 命令访问非默认22端口。
ssh :(命令中的 p 小写) ssh -p 端口号 root@服务器ip scp: (命令中的 P 大写)(-r表示将目录下的目录递归拷贝.“.*”是将所有文件包括隐藏文件.) 上传文件到服务器s ...
- TextBox 控件
TextBox控件上有一个箭头,MultiLine属性,是多行显示 TextBox控件有System.Windows.TextBox类提供,提供了基本的文本输入和编辑功能 属性 A ...
- 撩课-Python-每天5道面试题-第9天
一. Python程序中, 文件的处理步骤是什么? 打开 open("文件","模式") 读写 2.1 读 f.read(字节数) 字节数默认是文件内容长度 下 ...
- 手把手教你写一个RPC
1.1 RPC 是什么 定义:RPC(Remote Procedure Call Protocol)--远程过程调用协议 ,RPC协议假定某些传输协议的存在,如TCP或UDP,为通信程序之间携带信息数 ...
- IO实战-RandomAccessFile在本地实现伪断点续传
准备:在磁盘中 准备一个目录文件 实现:将该文件复制到目标路径中,关掉程序,再重新打开可以在原位置继续复制. 需求如下: 过程中显示文件的拷贝的百分比 复制过程中关掉程序. 重新启动该程序时,若上次没 ...