django的orm操作的补充
---恢复内容开始---
你在建立一个登陆的时候需要用到auth这个用户登陆模块 这个时候就需要用到user表中的信息你就可以继承 这个时候我们的用户表中继承我们user继承的表 ABstractUser表 然后再在settings内设置信息告诉django
AUTH_USER_MODEL="once.UserInfo" AUTH_USER_MODEL = '你的app.UserInfo'
就是告诉你的django你的models内继承了这个类
然后导入这个类
from django.contrib.auth.models import AbstractUser
from django.contrib.auth.models import AbstractUser # 导入一个你的auth组件需要用到的user的继承的类 这样我们就可以让我们新建立的用户表也可以用到了我们auth的内容
我们后面会用到django提供的web版本的数据库操作方便添加信息 这个时候就需要你的创建数据库的时候给你的字段赋值 让你的 django的可以方便识别
verbose_name 这个是给你的字段加上一个web数据库可以识别的信息
models:
from django.db import models
# Create your models here.
from django.contrib.auth.models import AbstractUser # 导入一个你的auth组件需要用到的user的继承的类 这样我们就可以让我们新建立的用户表也可以用到了我们auth的内容
class UserInfo(AbstractUser):
'''
用户信息表
'''
nid = models.AutoField(primary_key = True) #设置一个id主键
telephone = models.CharField(max_length = 11,null= True, unique = True ) #设置手机号 可以为空 然后不可以相同
avatar = models.FileField(upload_to = 'avatars/', default = 'avatars/default.png') # 这个是设置一个存放关于 user的用户的图片的信息都放在这个所建立的文件夹内
create_time = models.DateTimeField(verbose_name='创建时间', auto_now_add = True)
blog = models.OneToOneField(to='Blog',to_field='nid',null= True,on_delete=models.CASCADE)
#人和博客是一对一的 所以是一对一的建立
#不哟个再此设置姓名密码了 因为继承的有
def __str__(self):
return self.username
# verbose_name这个字段代表的是你的数据库在关联界面的时候进行的操作 可以显示在web关联界面的
class Blog(models.Model):
'''
博客信息
'''
nid = models.AutoField(primary_key = True)
title = models.CharField(verbose_name='个人博客标题',max_length= 64)
size_name = models.CharField(verbose_name = '站点名称', max_length = 64)
theme = models.CharField(verbose_name = '博客主题',max_length = 32)
def __str__(self):
return self.title
class Category(models.Model):
'''
博主的个人文章分类表
'''
nid = models.AutoField(primary_key = True)
title = models.ForeignKey(to='Blog',verbose_name = '所属博客', to_field='nid', on_delete=models.CASCADE)
def __str__(self):
return self.title
class Tag(models.Model):
'''标签'''
nid = models.AutoField(primary_key = True)
title = models.CharField(verbose_name = '标签名称',max_length = 32)
blog = models.ForeignKey(verbose_name = '所属博客',to = 'Blog',to_field='nid',on_delete = models.CASCADE)
def __str__(self):
return self.title
class Article(models.Model):
'''
文章表
'''
nid = models.AutoField(primary_key = True)
title = models.CharField(max_length = 60,verbose_name = '文章标题')
desc = models.CharField(max_length = 300,verbose_name = '文章描述')
create_time = models.DateTimeField(verbose_name = '创建时间',auto_now_add= True)
cntent = models.TextField() #评论内容
comment_count = models.IntegerField(default = 0) #评论数量
up_count = models.IntegerField(default = 0) # 点赞
down_count = models.IntegerField(default = 0) # 踩的数量
user = models.ForeignKey(to ='Category', to_field='nid',null=True,on_delete= models.CASCADE) # 这个是把文章和分类建立起外键
tags = models.ManyToManyField(
to = 'Tag',
through = 'Article2Tag', #第三张表你可以自己创建也可以你选择的创建用through来创建第三张关系表
)
class Article2Tag(models.Model):
'''
这个是文章表和标签的关系表 多对多的表
'''
nid = models.AutoField(primary_key = True)
article = models.ForeignKey(verbose_name = '文章',to='Article',to_field='nid',on_delete = models.CASCADE) #这个关联的是文章的表的字段
tag = models.ForeignKey(verbose_name = '标签',to='Tag',to_field='nid',on_delete=models.CASCADE) #这个是关联的你的标签的字段
class Meta: #联合索引
unique_together = [
('article','tag')
]
def __str__(self):
v = self.article.title+'---'+self.tag.title
return v
class ArticleUpDown(models.Model):
'''
点赞表
'''
nid = models.AutoField(primary_key = True)
user = models.ForeignKey('UserInfo',null=True,on_delete=models.CASCADE) #和userinfo建立起外键
article = models.ForeignKey('Article',null=True,on_delete=models.CASCADE) #和文章表建立外键
is_up = models.BooleanField(default=True) #判断是否点赞
class Meta:
unique_together=[
('article','user') #建立联合索引
]
class Comment(models.Model):
'''
评论表
'''
nid = models.AutoField(primary_key = True)
article = models.ForeignKey(verbose_name = '评论文章',to='Article',to_field = 'nid',on_delete=models.CASCADE)
user = models.ForeignKey(verbose_name='评论者',to='UserInfo',to_field='nid',on_delete=models.CASCADE)
content = models.CharField(verbose_name = '评论内容',max_length =255)
create_time =models.DateTimeField(verbose_name = '创建时间',auto_now_add=True)
parent_comment = models.ForeignKey('Comment',null = True,on_delete=models.CASCADE) #自己关联自己其实就是为了你的评论的时候找到是哪个评论的 然后就根据你上一次的评论的来回复 就是你要找到你要回复的是哪一个评论
def __str__(self):
return self.content
models
---恢复内容结束---
django的orm操作的补充的更多相关文章
- Django之ORM操作
Django之ORM操作 前言 Django框架功能齐全自带数据库操作功能,本文主要介绍Django的ORM框架 到目前为止,当我们的程序涉及到数据库相关操作时,我们一般都会这么搞: 创建数据库,设计 ...
- Django之ORM操作(聚合 分组、F Q)
Django之ORM操作(聚合 分组.F Q) 聚合 aggregate()是QuerySet的一个终止子句,也就是说,他返回一个包含一些键值对的字典,在它的后面不可以再进行点(.)操作. 键的名 ...
- Django之ORM操作(***)
Django之ORM操作(***) http请求的流程: url--> 视图view(模板+数据库) --> ORM的功能: 可以转换SQL语句,并做操作. ORM操作数据表: -创建表: ...
- 【Django】ORM操作#2
目录 必知必会的13条查询方法 单表查询之神奇的双下划线 一对多 ForeignKey 多对多 ManyToManyField 在Python脚本中调用Django环境 Django终端打印SQL语句 ...
- 【Django】ORM操作#1
目录 一.介绍 概念 由来 优势 劣势 总结 二.Django中的ORM Django项目使用MySQL Model 快速入门 1. AutoField 2. IntegerField 3. Char ...
- django的orm操作优化
django的orm操作优化 models.py from django.db import models class Author(models.Model): name = models.Char ...
- Django中ORM操作
ORM操作: class UserInfo(models.Model): username = models.CharField(max_length=32) password = models.Ch ...
- Django的ORM操作
ORM操作 select * from tb where id > 1 # 对应关系 models.tb.objects.filter(id__gt=1) models.tb.objects.f ...
- Django之ORM操作总结
Django之ORM总结 表结构 from django.db import models # 一对多:班级与学生 # 多对多:班级与老师 # Create your models here. #创建 ...
随机推荐
- LeetCode-13. Roman to Integer(罗马数字转阿拉伯数字)
1.题目描述 Given a roman numeral, convert it to an integer. Input is guaranteed to be within the range f ...
- PHP之string之str_word_count()函数使用
str_word_count (PHP 4 >= 4.3.0, PHP 5, PHP 7) str_word_count - Return information about words use ...
- 作为一个编程新手,我再也不怕Flink迷了我的眼!
欢迎大家前往腾讯云+社区,获取更多腾讯海量技术实践干货哦~ 本文由kyledong发表于云+社区专栏 使用 Flink 编写处理逻辑时,新手总是容易被林林总总的概念所混淆: 为什么 Flink 有那么 ...
- 10种jquery选择器操作详解(转)
jquery选择器大体上可分为4 类: 1.基本选择器2.层次选择器3.过滤选择器4.表单选择器 其中过滤选择器可以分为:1.简单过滤选择器2.内容过滤选择器3.可见性过滤选择器4.属性过滤选择器5. ...
- C# Winform程序CPU占用高的原因和解决方法
程序CPU占用高的可能原因: 1.存在死循环: 为什么死循环会导致CPU占用高呢? 虽然分时操作系统是采用时间片的机制对CPU的时间进行管理的,也就是说到了一定时间它会自动从一个进程切换到下 ...
- JavaScript中自定义函数以及文本框、radio、下拉框的值的获取,结合淘宝竞拍案例来理解。。。
淘宝竞拍案例: HTML部分代码: <form action="#" method="post"> <h2>欢迎进入淘宝竞拍</h ...
- [C语言] 数据结构概述
1.数据结构概述 定义 我们如何把现实中大量而复杂的问题以特定的数据类型和特定的存储结构保存到主存储器(内存)中, 以及在此基础上为实现某个功能(比如查找.删除.查找.某个元素,对所有元素进行排序)而 ...
- iOS开发之工具篇-20个可以帮你简化移动app开发流程的工具
如果想进入移动app开发这个领域,你总能从别的开发者或者网上或者书上找到各种各样的方法和工具,对于新手来说,还没有摸清门路就已经陷入迷茫了.这里推荐20个可以帮你简化app开发流程的工具.很多开发者都 ...
- memcache 学习笔记
Memcached是国外社区网站LiveJournal的开发团队开发的高性能的分布式内存缓存服务器.一般的使用目的是,通过缓存数据库查询结果,减少数据库访问次数,以提高动态Web应用的速度.提高可扩展 ...
- Java中URL重写(urlrewrite+Maven)
一.UrlRewrite的作用 UrlRewrite即地址重写,用户得到的全部都是经过处理后的URL地址.将我们的动态网页地址转化为静态的地址,如html.shtml,还可以隐藏网页的真正路径.此 ...