Django实践笔记

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
简介: Django实战笔记

Django应用框架

安装Django:
pip install django -i http://pypi.douban.com/simple --trusted-host pypi.douban.com
创建Django项目
django-admin startproject DjangoDemo1
文件目录层级说明
manage.py:一个命令行工具,可以使我们用多种方式对Django项目进行交互
project项目目录
init.py:一个空文件,它告诉python这个目录应该被看做一个python包
setting.py:项目的配置文件
urls.py:项目的URL声明
wsgi.py:项目与WSGI兼容的Web服务器入口
windows安装mysql:
下载地址:https://dev.mysql.com/downloads/mysql/
跳过登录直接下载
环境变量
变量名:MYSQL_HOME
变量值:E:mysql-5.7.20-winx64
以管理员身份运行cmd
进入D:mysql-8.0.12-winx64bin
执行:mysqld --initialize-insecure --user=mysql #会生成目录下生成data目录
管理员运行:mysqld -install
启动服务:
net start MySQL
连接:
mysql -u root -p
修改setting.py文件:
DATABASES = {
'default': {
'ENGINE': 'django.db.backends.mysql',
'NAME': 'sunck',
'USER': 'root',
'PASSWORD': '',
'HOST': 'localhost',
'PORT': '3306'
}
}
创建:app01
执行 python manage.py startapp app01
在setting中奖app01应用加入INSTALL_APPS选项中
INSTALLED_APPS = [
'django.contrib.admin',
'django.contrib.auth',
'django.contrib.contenttypes',
'django.contrib.sessions',
'django.contrib.messages',
'django.contrib.staticfiles',
'app01'
]
创建模型:model.py文件中
class Grades(models.Model):

gname = models.CharField(max_length=20)
gdate = models.DateTimeField()
ggirlnum = models.IntegerField()
gboynum = models.IntegerField()
isDelete = models.BooleanField(default=False)

class Students(models.Model):

sname = models.CharField(max_length=20)
sgender = models.BooleanField(default=True)
sage = models.IntegerField()
scontent = models.CharField(max_length=20)
isDelete = models.BooleanField(default=False)

关联外键
sgrade = models.ForeignKey("Grades")

生成数据表在数据库中
生成迁移文件:python manage.py makemigrations #在migrations目录下生成一个迁移文件
执行迁移:python manage.py migrate
执行完之后去数据库中查询数据,发现表已经生成。
测试数据操作
进入python shell : python manage.py shell
引入一些包:
from app01.models import Grades,Students
from django.utils import timezone
from datetime import *
查询所有数据
Grades.object.all()
添加数据:创建一个模型类的对象实例
创建对象
grade1 = Grades()
grade1.gname = "gaojianshuai"
grade1.gdate = datetime(year=2019,month=12,day=9)
grade1.ggirlnum = 3
grade1.gboynum=30
grade1.save()
grade2.gname = "linjiayin"
grade2.ggirlnum = 4
grade2.gboynum=13
grade2.gdate = datetime(year=2020,month=1,day=25)
grade2.save()
查看某个对象:
Grades.objects.all()
Grades.objects.get(pk=1)
Grades.objects.get(pk=2)
grade2
修改某个属性:模型对象.属性 = 新值
grade2.ggirlnum = 555
grade2.save()
删除数据:
模型对象.delete() grade2.delete()
启动服务器:
python manage.py runserver
admin站点管理:

内容发布:负责添加、修改、删除内容

配置admin应用:在setting中的INSTALL_APPS中添加'django.contrib.admin',默认是已经添加好的

创建管理员用户:python manage.py createsuperuser

账号密码:sunck 1234567890

访问:127.0.0.1:8000
127.0.0.1:8000/admin
界面汉化
在setting文件中修改如下
LANGUAGE_CODE = 'en-us' #修改为zh-Hans
TIME_ZONE = 'Asia/Shanghai'
管理数据表
通过修改admin.py文件:
from .models import Grades,Students

注册

admin.site.register(Grades)
admin.site.register(Students)
自定义管理页面:

列表页

list_display = ['pk', 'gname', 'gdate', 'ggirlnum', 'gboynum']#显示字段
list_filter = ['gname']#过滤字段
search_fields = ['gname']#搜索字段
list_per_page = 5#分页

添加,修改页面

fields = [ 'gname', 'ggirlnum', 'gdate', 'gboynum', 'idDelete']#属性的先后顺序

fieldsets = #给属性分组

注意:field与fieldset不能同时使用

相关实践学习
如何快速连接云数据库RDS MySQL
本场景介绍如何通过阿里云数据管理服务DMS快速连接云数据库RDS MySQL,然后进行数据表的CRUD操作。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
2月前
|
存储 缓存 NoSQL
深入理解Django与Redis的集成实践
深入理解Django与Redis的集成实践
86 0
|
4月前
|
存储 监控 数据库
Django 后端架构开发:高效日志规范与实践
Django 后端架构开发:高效日志规范与实践
88 1
|
7月前
|
Python API 网络架构
Django实践-10RESTful架构和DRF入门
Django实践-10RESTful架构和DRF入门
Django实践-10RESTful架构和DRF入门
|
7月前
|
中间件 程序员 开发工具
Django实践-08中间件的应用
Django实践-08中间件的应用
Django实践-08中间件的应用
|
1月前
|
SQL 监控 数据库
深入探索Django ORM:高效数据操作的秘诀与实践####
在当今的Web开发领域,提升数据访问层的效率是优化应用性能的关键。本文旨在通过剖析Django框架中的ORM(对象关系映射)机制,揭示其如何简化数据库交互,并探讨一系列高级技巧与策略,帮助开发者构建更高效、可维护的数据访问代码。我们不涉及安装步骤或基础概念,而是聚焦于实战经验分享,旨在为中高级开发者提供深度洞见。 ####
|
3月前
|
前端开发 数据库 数据安全/隐私保护
|
4月前
|
负载均衡 应用服务中间件 网络安全
Django后端架构开发:Nginx服务优化实践
Django后端架构开发:Nginx服务优化实践
75 2
|
4月前
|
JSON API 数据安全/隐私保护
Django 后端架构开发:JWT 项目实践与Drf版本控制
Django 后端架构开发:JWT 项目实践与Drf版本控制
99 0
|
5月前
|
安全 API 网络安全
Django RESTful API安全实践
【7月更文挑战第19天】构建安全的Django RESTful API需要综合考虑多个方面,包括身份验证与授权、数据验证与清洗、安全的HTTPS连接、限制请求频率以及审计与日志记录等。通过实施这些安全实践,可以有效地保护API服务免受各种安全威胁的侵害,确保用户数据的安全性和服务的可用性。开发者在开发RESTful API时,应始终将安全性放在首位,确保API服务的安全可靠。
|
6月前
|
存储 监控 调度
Django中的定时任务与后台任务队列的实践
【6月更文挑战第10天】在Django中实现定时任务和后台任务队列,可以使用Celery+Beat进行定时任务,Django Q处理后台任务。Celery配置包括设置Broker和Result Backend,创建Celery实例及任务。Django Q则涉及安装、配置ORM和创建任务。通过`async_task`将任务放入队列。注意性能、资源、安全和错误处理。使用时需考虑认证、输入验证、日志监控、部署策略和测试质量保障。
Django中的定时任务与后台任务队列的实践