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‘)

# 顶踩表:记录你顶过那个用户的哪条新闻,踩过哪个用户的哪条新闻

原文地址:https://www.cnblogs.com/ftl1012/p/9410825.html

时间: 2024-07-29 17:55:11

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

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

Django ORM操作     1. 字段操作         class User(model.Model);             u=字段        用处:            1 .admin中的字段验证            2. obj.clean_fields() 进行自定义的验证             3. 利用Djanfo Form进行验证,此时前台和后台的操作分开               但form和model里的字段重复[推荐使用]             

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

注: 此处的小评论涉及数据库操作 初级小评论代码 settings.py INSTALLED_APPS = [ ... 'app01', # 注册app ] STATICFILES_DIRS = (os.path.join(BASE_DIR, "statics"),) # 现添加的配置,这里是元组,注意逗号 TEMPLATES = [ ... 'DIRS': [os.path.join(BASE_DIR, 'templates')], ] urls.py from django.con

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

实际上就是多了一个隐藏的span标签,内容是+1,配合setInterval实现的动态效果 settings.py INSTALLED_APPS = [ ... 'app01', # 注册app ] STATICFILES_DIRS = (os.path.join(BASE_DIR, "statics"),) # 现添加的配置,这里是元组,注意逗号 TEMPLATES = [ ... 'DIRS': [os.path.join(BASE_DIR, 'templates')], ] ur

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

点赞功能分析 前台传递过来新闻id[new_id]和session[session内有用户ID和用户之间的信息]到后台 后台News数据库内用户和新闻是多对多的关系,查看第三张表中的内容,判读用户Id所对应的信息里有没有new_id,如果有则remove[取消点赞],否则增加一条点赞 obj = News.objects.get(new_id=id) b = obj.favor.filter(uid=request.session['uid']).count() if b: obj.remove

[TimLinux] Python学习内容框架

以下内容主体来自<Python学习手册第四版>,大致整理出的方向 1. 第一部分:使用入门 介绍Python语法之前,先对Python的的各个方面进行一个比较宽广的介绍,包含对Python的一些问题,Python程序的运行方式,给出示例演示Python是如何运行的.这部分的学习,粗略的过一下即可,建议花时间在2小时内,总页数在60页左右.包含的章节如下: 2. 第二部分:类型与运算 这部分内容是Python语言的基础中的基础,对Python的内建基本数据类型进行了详细的介绍,需要精度的部分之一

Python三大主流框架分析

python三大主流框架 """ Django: 大而全 自带的功能特别特别多 类似于航空母舰 有时候过于笨重 Flask 小而精 自带的功能特别特别少 类似于游骑兵 第三方的模块特别特别多,如果将flask第三方模块全部加起来 完全可以超过django 比较依赖于第三方模块 Tornado 异步非阻塞 牛逼到可以开发游戏服务器 A:socket部分 B:路由与视图函数对应关系 C:模板语法 Django: A用的别人的 wsgiref B自己写的 C自己写的 Flask A

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

1 Python标准数据库接口DB-API介绍 Python标准数据库接口为 Python DB-API,它为开发人员提供了数据库应用编程接口.Python DB-API支持很多种的数据库,你可以选择跟自己项目相关的数据库.Python DB-API支持的数据库如下所示: GadFly mSQL MySQL PostgreSQL Microsoft SQL Server 2000 Informix Interbase Oracle Sybase 不同的数据库你需要下载不同的DB API模块,例如

Python学习——web框架

对于所有的Web应用,本质上其实就是一个socket服务端,用户的浏览器其实就是一个socket客户端. WSGI(Web Server Gateway Interface)是一种规范,它定义了使用python编写的web app与web server之间接口格式,实现web app与web server间的解耦. 一.python标准库提供的独立WSGI服务器称为wsgiref 1 from wsgiref.simple_server import make_server 2 3 def Ru

python 学习之—连接oracle 数据库

我们在测试中可能需要对oracle 数据库进行操纵,比如这样一个场景,在往oracle 里面插数据的同时,另一个工具从里面读,如何能保证读出来的数据是有顺序的,即:先插入进去的先读出来,根据这个场景们首先需要制作一个不断往oracle 数据库里面插入数据的脚本.这个时候我们想到了python 的cx_Oracle库,下面我们就来实现一下: import cx_Oracle import time ISOTIMEFORMAT='%Y-%m-%d %X' def connectOracle(): c