当前位置: 首页 > news >正文

Django笔记(五):模型models

Django中的模型对应数据库中的一张表格。

定义模型

player.py

from django.db import modelsclass Player(models.Model):idx = models.IntegerField(unique=True)def __str__(self):return str(self.id)

每个模型需要继承models类,如上Player模型定义了一个整形字段idx。常见字段类型有:

字段

描述
IntegerField整形
FloatField浮点型
CharField字符串类型

TextField

长文本类型
BooleanField布尔类型

每个字段可定义参数:

参数取值描述
nullTrue/False是否为空
uniqueTrue/False字段是否唯一
defaultauto字段默认值
max_lengthint字段最大长度
primary_keyTrue/False是否为主键

迁移数据

定义好模型后,需要进行迁移才能在数据库中看到表格:

python manage.py makemigrations // 生成迁移文件
python manage.py migrate // 执行迁移

后台管理

Django自带一个后台,访问localhost/admin/可以看到,如果想让自己创建的表格能够在后台可视化,需要将表格进行注册。在models所属app目录下编辑admin.py:

from django.contrib import admin
from app1.models.player import Player # 引入模型# Register your models here.admin.site.register(Player) # 注册模型

迁移后需要重启服务器,admin后台才能看到更新之后的自定义表格。

数据库操作

Django定义了一系列API对数据库执行操作,无需关注不同数据库间sql语句的差别,例如查询Player的所有记录:

from django.http import HttpResponse
from app1.models.player import Playerdef GetPlayersView(request):player = Player.objects.all()for p in player:print(p.idx)return HttpResponse("")

常用查询操作如下:

方法描述返回
all查询所有查询集(可当做列表)
filter多条查询列表
get单条查询一条数据,查询失败报错
count查询结果数整数

一般查询不确定结果使用filter,如查询一个idx为10010的用户,可以使用

player = Player.objects.filter(idx=10010)
if player:print(player[0].idx)
else:print("no result")

这样可以避免get方法查询为空时的报错。

Player.objects.create(idx=1)

players = Player.objects.filter(status=123)
for player in players:player.delete()

# 单条修改
player = Player.objects.get(id=1)
player.status = 123
player.save()# 批量修改
players = Player.objects.filter(id=1).update(status=123)

User模型

Django自带User模型,内置用户认证体系,开箱即用。

User模型常用字段:

字段类型描述
idint主键,用户编号
usernamevarchar用户名
passwordvarchar密码
is_activetinyint用户状态,为0则封号

常用操作:

from django.contrib.auth.models import User# 创建user
User.objects.create_user(username="", password="")# 修改密码
user = User.objects.get(id=1)
user.set_password(passwd)
user.save()# 验证密码
user.check_password(passwd)

Auth模块

常见方法:

方法描述
authenticate(username, password)用户验证
login(HttpRequest, user)登录
logout(request)登出,注销会话
is_authenticated()用户登录状态

用户登录视图:

from django.http import JsonResponse
from django.contrib.auth import authenticate, logindef signin(request):data = request.POSTusername = data.get("username")password = data.get("password")user = authenticate(username=username, password=password) # 验证用户if not user:return JsonResponse({"result": "用户名或密码错误"})if user.is_authenticated():return JsonResponse({"result": "用户已登录"})if user.is_authenticated():return JsonResponse({"result": "用户已登录"})if not user.is_active:return JsonResponse({"result": "账号被封"})# 登录用户login(request, user)return JsonResponse({"result": "success"})

扩展用户

Django自带的User未必能够满足我们所有的需求,故其提供了扩展User的方式,而个人更喜欢偷个懒,例如文章开头的Player想对User扩展,我会这样写:

from django.db import models
from django.contrib.auth.models import Userclass Player(models.Model):user = models.OneToOneField(User, on_delete=models.CASCADE)...def __str__(self):return str(self.user)

将User和Player俩个表做个关联,让user成为Player的一个字段来使用。

(模型的关系除了一对一OneToOneField,还有一对多ForeignKey和多对多ManyToManyField,on_delete的参数CASCADE表级联删除,还有PROTECT和DO_NOTHING等对扩展表的操作)

http://www.lryc.cn/news/285079.html

相关文章:

  • 一个golang小白使用vscode搭建Ununtu20.04下的go开发环境
  • 【复现】Hytec Inter HWL 2511 SS路由器RCE漏洞_25
  • Kafka系列(四)
  • 【Linux学习】进程信号
  • 机器学习没那么难,Azure AutoML帮你简单3步实现自动化模型训练
  • 数学建模实战Matlab绘图
  • TypeError the JSON object must be str, bytes or bytearray, not ‘list‘
  • 数字IC后端设计实现 | PR工具中到底应该如何控制density和congestion?(ICC2Innovus)
  • 产品经理与产品运营的区别和联系
  • CMU15-445-Spring-2023-分布式DBMS初探(lec21-24)
  • Arch linux 安装
  • 最新ChatGPT/GPT4科研应用与AI绘图及论文高效写作
  • 【leetcode】移除元素
  • Spring Boot整合Redis的高效数据缓存实践
  • FastApi-参数接收的正确使用(2)
  • 三、需求规格说明书(软件工程示例)
  • Elasticsearch 查询语句概述
  • kafka简单介绍和代码示例
  • 一次解决ForkJoinPool日志追踪的辛酸经历
  • VM使用教程--SDK取图 视频笔记
  • 11.spring boot 启动源码(一)
  • 【微服务】springcloud集成sleuth与zipkin实现链路追踪
  • 数学建模-预测人口数据
  • SpringBoot 集成 Canal 基于 MySQL 做数据同步
  • 【CVE-2022-22733漏洞复现】
  • Python爬虫---scrapy框架---当当网管道封装
  • 【机器学习】机器学习四大类第01课
  • 下述默认构造函数有什么问题?
  • vite和mockjs配合使用
  • 【数据结构】常见八大排序算法总结