Django-Django项目与应用的创建与介绍-Django请求的生命周期-配置Mysql完成数据迁移-ORM记录的增删改查

一、Django项目的创建与介绍
安装:pip3 install django==1.11.x
查看版本号:django-admin --version
新建项目:1.前往项目目录 2.django-admin startproject proj_name

proj_name:项目目录,包含项目最基本的一些配置
	-- __init__.py:模块的配置文件
	-- settings.py:配置总文件
	-- urls.py:url配置文件,django项目中的所有页面都需要对其配置url地址
	-- wsgi.py:(web server gateway interface),服务器网关接口,python应用与web服务器直接通信的接口
templates:模板文件夹,存放html文件的(页面),支持使用Django模板语言(DTL),也可以使用第三方(jinja2)
manage.py:项目管理器,与项目交互的命令行工具集的入口,查看支持的所有命令python3 manage.py
二、应用的创建与介绍
1.Django是面向应用开发,在应用中完成具体的业务逻辑
2.什么是应用app: 就好比项目中的一个功能模块,一个项目可以拥有多个功能模块,但至少得有一个,Django称之为app
3.如何创建app(在项目目录下):python3 manage.py startapp app01

migrations:数据迁移(移植)模块,内容都是由Django自动生成
	-- __init__.py
__init__.py
admin.py:应用的后台管理系统配置
apps.py:django 1.9后,本应用的相关配置
models.py:数据模型模块,使用ORM框架,类似于MVC模式下的Model层
tests.py:自动化测试模块,可以写自动化测试脚本
views.py:执行相应的逻辑代码模块
三、启动项目
终端:python3 manage.py runserver 127.0.0.1:8801
四、pycharm创建启动项目
1.创建Django
2.选择项目目录(从项目目录开始,目录文件夹及子文件夹不要出现中文,保证电脑名字不能为中文)
3.配置默认模板语言,模板路径,app名
4.启动
五、生命周期
1.浏览器发送请求
2.wsgi服务器接收到请求,将请求解析交给Django
3.Django中间件过滤请求信息,交给路由
4.路由完成业务逻辑的分发,到指定app下views中指定的视图函数
5.视图函数完成具体的业务逻辑,返回响应结果
6.将处理结果通过服务器返回给浏览器
六、三件套
from django.shortcuts import HttpResponse, render, redirect

# 返回字符串
def action1(request):
    return HttpResponse("基础信息")

# 返回一个页面
def action2(request):
    return render(request, 'template_page.html', {k:v})
    
# 重定向
def action3(request):
    return redirect('/index/')
七、静态文件
1.在settings.py中配置
STATIC_URL = '/static/'  # 静态文件请求根路由
STATICFILES_DIRS = [
    os.path.join(BASE_DIR, 'static')   # 静态文件检索的文件夹
]
2.在项目根目录下创建static文件夹
3.静态文件就放在static根目录或子目录下
4.获取静态文件:/static/目标文件(可以包含static子文件夹路径)
八、请求及数据
请求路径:
1.空着:默认向当前路径发送请求
2.http://127.0.0.1:8801/testAction/:向testAction路径发送请求
3./testAction/: 向testAction路径发送请求(推荐)

在视图函数中
请求方式:request.method
GET请求获取数据:request.GET.get('key', None)  # 当key不存在,用None替换
POST请求获取数据:request.POST.get('key', None)  # 当key不存在,用None替换
九、配置Mysql完成数据迁移
1.在settings.py配置Mysql数据库信息
DATABASES = {
    'default': {
        'ENGINE': 'django.db.backends.mysql',
        'NAME': 'dg2',
        'HOST': '192.168.32.100',
        'PORT': 3306,
        'USER': 'root',
        'PASSWORD': '123456'
    }
}

2.在项目或应用的init文件中修改连接数据库的模块为pymysql
import pymysql
pymysql.install_as_MySQLdb()

3.在项目目录下,执行(生成迁移数据,没有映射到数据库):python3 manage.py makemigrations

4.将迁移数据映射到数据库:python3 manage.py migrate
十、单表ORM记录的增删改查
# 增
User.objects.create(usr='abc', pwd='123')  # 第一种方式
user = User(usr='owen', pwd='123')
user.save()  # 第二种方式

# 删
User.objects.filter(id=1).delete()

# 改
User.objects.filter(pwd='123').update(pwd='000')

# 查
User.objects.filter(pwd='000').all()
User.objects.filter(pwd='000').first()
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值