---恢复内容开始---

你在建立一个登陆的时候需要用到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操作的补充的更多相关文章

  1. Django之ORM操作

    Django之ORM操作 前言 Django框架功能齐全自带数据库操作功能,本文主要介绍Django的ORM框架 到目前为止,当我们的程序涉及到数据库相关操作时,我们一般都会这么搞: 创建数据库,设计 ...

  2. Django之ORM操作(聚合 分组、F Q)

    Django之ORM操作(聚合 分组.F Q) 聚合 aggregate()是QuerySet的一个终止子句,也就是说,他返回一个包含一些键值对的字典,在它的后面不可以再进行点(.)操作.   键的名 ...

  3. Django之ORM操作(***)

    Django之ORM操作(***) http请求的流程: url--> 视图view(模板+数据库) --> ORM的功能: 可以转换SQL语句,并做操作. ORM操作数据表: -创建表: ...

  4. 【Django】ORM操作#2

    目录 必知必会的13条查询方法 单表查询之神奇的双下划线 一对多 ForeignKey 多对多 ManyToManyField 在Python脚本中调用Django环境 Django终端打印SQL语句 ...

  5. 【Django】ORM操作#1

    目录 一.介绍 概念 由来 优势 劣势 总结 二.Django中的ORM Django项目使用MySQL Model 快速入门 1. AutoField 2. IntegerField 3. Char ...

  6. django的orm操作优化

    django的orm操作优化 models.py from django.db import models class Author(models.Model): name = models.Char ...

  7. Django中ORM操作

    ORM操作: class UserInfo(models.Model): username = models.CharField(max_length=32) password = models.Ch ...

  8. Django的ORM操作

    ORM操作 select * from tb where id > 1 # 对应关系 models.tb.objects.filter(id__gt=1) models.tb.objects.f ...

  9. Django之ORM操作总结

    Django之ORM总结 表结构 from django.db import models # 一对多:班级与学生 # 多对多:班级与老师 # Create your models here. #创建 ...

随机推荐

  1. python安装及配置

     1.进入python官网https://www.python.org/2.导航栏选择Download -> Windows3.按照系统版本点击选择32.64位安装包64 Windows x86 ...

  2. 【Maven学习】远程仓库的配置

    很多情况下,默认的中央仓库无法满足项目的需求,我们可能需要配置新的远程仓库,此时我们可以这样配置: <repository> <id>java-net</id> & ...

  3. rocksDB vs InnoDB vsTokuDB

    原文地址 https://minervadb.com/index.php/2018/08/06/comparing-tokudb-rocksdb-and-innodb-performance-on-i ...

  4. DOS命令行操作MySQL数据库中文乱码问题解决

    我们在 dos 命令行操作中文时,会报错 ’); ERROR (HY000): Incorrect string value: '\xD5\xC5\xC8\xFD' for column 原因:因为 ...

  5. JavaScript设计模式-17.装饰者模式(下)

    <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title> ...

  6. 解决问题的思维方式之Problem->Desgin->Solution(笔记)

    Problem->Desgin->Solution: 1.对于每个需要实现的功能问题,我们都称之为Problem(问题). 2.解决问题的具体思考过程,寻求解决问题的方案,即为Desgin ...

  7. java class load 类加载

    1:what is  it jvm把描述类的数据从class字节码文件加载到内存,并对数据进行校验.解析.初始化,最终成为jvm直接使用的数据类型 1.ClassNotFoundExcetpion  ...

  8. 关于对Enum的理解

    之前一直对枚举类型的理解存在误解,现重新学习 Enum 类型的介绍 枚举类型(Enumerated Type) 很早就出现在编程语言中,它被用来将一组类似的值包含到一种类型当中.而这种枚举类型的名称则 ...

  9. 查询MySQL数据表的字段名和表结构

    查询表的字段: -- 查询表的字段名 SELECT COLUMN_NAME -- GROUP_CONCAT('a.', COLUMN_NAME SEPARATOR ',') AS COLUMN_NAM ...

  10. laravel5.4学习--laravel基本路由

    最基本的 Laravel 路由只接收一个 URI 和一个闭包,并以此提供一个非常简单且优雅的定义路由方法: Route::get('foo', function () {return 'Hello W ...