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

太原做微网站的公司建网站专业

太原做微网站的公司,建网站专业,美工做兼职在那个网站,装修设计 在线首 Django中的模型对应数据库中的一张表格。 定义模型 player.py from django.db import modelsclass Player(models.Model):idx models.IntegerField(uniqueTrue)def __str__(self):return str(self.id)每个模型需要继承models类,如上Player模型定义了一个整形…

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.hkea.cn/news/534820/

相关文章:

  • dw做汽车网站seo排名工具提升流量
  • 网络培训学校排名奉化seo页面优化外包
  • vps除了做网站还能做什么晨阳seo服务
  • seo网站建设优化什么意思网络营销与直播电商专业就业前景
  • 工程建设企业网站网站关键词优化应该怎么做
  • 修复wordpress青岛网站优化
  • 敦煌网站做外贸怎样网页推广怎么做的
  • 南京网站建设优化今日头条普通版
  • 网站编辑的工作职能有哪些活动营销案例100例
  • 小程序招商加盟平台我是seo关键词
  • wordpress 发帖机镇江抖音seo
  • 网站建设的小结可以发外链的论坛有哪些
  • 网站正常打开速度网店营销与推广策划方案
  • 义乌 网站制作进入百度app
  • 做外围网站赌球红树林seo基础入门免费教程
  • 绿色风格网站seo排名赚钱
  • 南宁企业免费建站百度推广营销怎么做
  • 建立个人网站的成本短视频seo营销系统
  • 深圳公司名称大全网站结构优化的内容和方法
  • 安康市代驾公司上海网站关键词排名优化报价
  • 怎么在网站上建设投票统计在线培训系统app
  • 泰州网站建设哪家好网站seo的主要优化内容
  • 洛卡博网站谁做的seo权重查询
  • 东莞网络科技公司有哪些山东网站seo
  • 网站建设需要学什么网站模板购买
  • 用html做的游戏网站关键词推广效果分析
  • 做影视网站引流正规推广平台有哪些
  • 免费下载简历模板北京seo排名厂家
  • 西昌市做网站的百度搜索排名靠前
  • 办公室装修实景拍摄图重庆seo俱乐部联系方式