昨日回顾
1 MTV和MVC
-MVC:model数据库相关操作,V:view视图,C:controler控制器,逻辑
-MTV:model数据库相关操作 T:template V:视图函数+路由匹配
2 django请求生命周期
-web服务器--》在wigiref中将http拆成字典---》调起可调用对象(django,flask,tornodo)---》路由匹配--》执行视图函数(数据库拿数据,模板文件拿模板,渲染)--》生成html页面--》返回
3 虚拟环境
-作用:隔离项目
-go mod
-java maven
4 orm介绍
-对象关系映射:
-数据中的一个表对应程序中一个类
-一条数据对应程序中一个对象
-django orm,sqlachemy
5 django orm简单使用
-不能创建数据库,手动创建数据库(sqlite不需要)
-django默认支持sqlite(不需要额外配置)
-models中写一个类(继承models.Model)
-写字段,注释掉字段,新增字段(default=默认值 或者 null=True)
-两条数据库迁移命令(一个是记录,一个是真正的迁移)
python manage.py makemigrations
python manage.py migrate
-插入
user=UserInfo(name=lqz,age=19)
user.save()
user=UserInfo.objects.create(name=lqz,age=19)
-查询所有
UserInfo.objects.all() # 放到列表中[user1,user2,user3]
今日内容
1 django连接mysql
1 如果项目使用sqlite,不需要额外配置,直接操作即可
2 django默认情况链接mysql,用的驱动是mysqldb模块,python 3.x以后,这个模块用不了了,咱们用的全都是pymysql,需要做个替换
3 showmigrations:查看哪些记录更改了,但是没有同步到数据库中
3 如果使用mysql,需要配置如下:
-1 配置文件中配置:settings.py
DATABASES = {
'default': {
'ENGINE': 'django.db.backends.mysql',
'NAME': 'day62',
'HOST': '127.0.0.1',
'PORT': 3306,
'USER': 'root',
'PASSWORD':'123'
}
}
-2 需要在 app的__init__.py 中写
import pymysql
pymysql.install_as_MySQLdb()
-3 后续操作完全一样,在models中建立类,写字段
-4 视图函数中插入,查询
-5 pycharm的--》tools---》run manage.py Task
2 pycharm操作sqlite和mysql
1 右侧datasource----》点点点就会了
3 路由层之简单路由配置
1 路由参数 其中url实际上就是一个函数
# 第一个参数是正则表达式
# 第二个参数是视图函数内存地址
# 第三个参数是个字典 {'name':lqz,'age':18},给视图函数传递默认值,会将字典的键传递当作参数,若视图函数接受的参数个数不对,则会报错
# 第四个参数name,当前路由的别名,用作反向解析
url(r'^home2/', views.home,{'name':'lqz','age':19},name='home'),
2 访问根路径,触发视图函数执行(路由怎么配)
-url(r'^$', admin.site.urls),
3 在路由中配置多个相同路由会怎么样?
只会执行第一个
4 如下路由会怎么样?永远不会匹配到第二个,因为正则直接匹配到了以login开头的所有字段
url(r'^login', views.home),
url(r'^login2', views.home),
4 路由层之APPEND_SLASH
1 路由配置如下
url(r'^login/$', views.home),
访问:http://127.0.0.1:8000/login/
访问:http://127.0.0.1:8000/login 两次请求,重定向了一次
2 去掉这种特性,在settings.py中写
APPEND_SLASH=False # 一般不加,默认为True,如果改成False,则在输入ip和端口号的文件路径后面不会默认将/加上,故上面的例子中第二个index未加/,访问将会报错
3 django如何实现的?通过一个中间件实现的django.middleware.common.CommonMiddleware(暂留)
5 有名分组 无名分组
#1 无名分组的使用
### 无名分组,把分组分出来的值,当作位置参数传递给视图函数
url(r'^login/([0-9]{4})/([0-9]{2})', views.login),
#2 有名分组的使用
### 有名分组,把分组出来的值,当作关键字参数传递给视图函数
url(r'^login/(?P<year>[0-9]{4})/(?P<month>[0-9]{2})', views.login),
#3 有什么作用
可以从url地址中解析出参数,传递给视图函数使用
#4 案例
# 这种地址,把人名和id分出来
# 有名分组
# ilovejaney/p/13748739.html
url(r'^(?P<name>.*?)/p/(?P<id>d+).html', views.article),
# 无名分组
url(r'^(.*?)/p/(d+).html', views.article),
有名分组和无名分组不能混用
# 5 伪静态
-原来是动态页面/login 做成/login.html 伪装成静态页面,便于seo优化
-seo优化:
-https://www.cnblogs.com/liuqingzheng/articles/9509792.html
6 路由分发
1 有一个总路径,根路由,总路由负责做分发
2 每个app有自己的路由和视图函数的对应关系
3 使用:
-1 在根路由中配置 导入from django.conf.urls import url,include
# 路由分发
# 第一种方式
# url(r'^app01',include('app01.urls') ),
# 第二种方式
url(r'^app01',include(urls) ), 这样导入,如果重名就会可能找不到正确的视图函数
-2 在不同app中新建urls.py
导入 from django.conf.urls import url,以及对应的视图函数
urlpatterns = [
url(r'login/', views.login),
url(r'home/', views.home),
]
-3 http://127.0.0.1:8000/app01/login/ 先匹配app01,如果成功分发到app01的urls中继续匹配
7 反向解析
1 通过路由的别名(此别名指的是整个),解析出路由的地址,并且能够访问url对应的视图函数,例如: home 对应的路由地址是形如 /login/home
2 用在视图函数中:
需要在from django.shortcuts import render, HttpResponse,redirect,reverse 导入reverse
url=reverse('home') # home就是路由的别名
print(url)
视图函数中别名,前面如果更改,获取的url后续使用时不用更改全部,只用更改前面使用,在重定向使用直接使用路由对应的别名的url,
3 模板文件中使用
{% url 'meinv' %}
模板文件中使用时,路径不需要更改
4 有什么作用
-动态根据路由别名获得路径,一旦路径改变,不需要改其他代码
8 名称空间
1 路由做反向解析时,有同名路由,出现问题
2 在做路由分发时,给每个app的路径设置一个名称空间,如果设置了名称名字,则在使用时必须带着名称空间的名字,否则会报错
3 使用步骤
1 在总路由中设置
url(r'^app01',include('app01.urls','名称空间的名字') ),
-2 用在视图函数中:
url=reverse('名称空间的名字:home') # home就是路由的别名
print(url)
-3 模板文件中使用
{% url '名称空间的名字:meinv' %}