一.昨日回顾
1 MTV和MVC
-MVC:model数据库相关操作,V:view视图,C:controler控制器,逻辑
-MTV:model数据库相关操作 T:template V:视图函数+路由匹配
2 Django请求生命周期
-web服务器-->http拆成字典-->调起可调用对象(Django,flask,tornodo)-->路由匹配-->执行视图
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()
二.Django链接mysql
1 如果项目使用sqlite,不需要额外配置,直接操作即可
2 Django默认情况链接mysql,用的驱动是mysqldb模块,python3.x以后,这个模块用不了了,所以我们用的全都是pymysql
3 showmigrations:查看哪些记录更改了,但是没有同步到数据库中
4 如果使用mysql,需要配置如下:
-1配置文件中配置:settings.py
DATABASES = {
'default':{
'ENGINE':'django.db.backends.mysql',
'NAME':'day62',
'HOST':'127.0.0.1',
'POST':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
三.pycharm操作sqlite和mysql
'''
明明链接上了数据库,但是看不到表无法操作
这个时候只需要将刚刚创建的链接删除 重新链接一次即可
'''
四 .路由层之简单路由配置
1 路由参数
url(r'^home2/',views.home,{'name':'lqz','age':19},name='home')
2 访问根路径,触发视图函数执行(路由怎么配)
-url(r'^$',admin.site.urls),
3 在路由中配置多个相同路由会怎样?
只会执行第一个
4 如下路由会怎么样?永远不会匹配到第二个
url(r'^login',views.home),
url(r'^login2',views.home),
'''
路由匹配从上往下匹配,一旦匹配成功,就不再往下匹配了
1.x的url以及2.x的re_path是正则匹配,
2.x的path是写什么地址,就匹配什么
因此,访问根路径时,path可以写:
path('',views.index)
也可以写:
path('/',views.index)
但是url或者re_path这样写就不对,所有的地址都会先匹配进这个地址,后面的匹配就白写了
应该写成
url(r'^$',views.index)
path(r'^$',views.index)
'''
五.路由层之APPEND_SLASH
1 路由配置如下
url(r'^login/$',views.home),
访问:http://127.0.0.1:8000/login/
访问:http://127.0.0.1:8080/login 两次请求,重定向了一次
2 去掉这种特性,在settings.py中写
APPEND_SLASH=False
3 Django如何实现的? 通过一个中间件实现的
Django.middleware.common.CommonMiddleware(暂留)
六.有名分组 无名分组
url(r'^login/([0-9]{4})/([0-9]{2})',views.login),
url(r'^login/(?P<year>[0-9]{4})/(?P<month>[0-9]{2})', views.login),
可以从url地址中解析出参数,传递给视图函数使用
url(r'^(?P<name>.*?)/p/(?P<id>\d+).html', views.article),
url(r'^(.*?)/p/(\d+).html', views.article),
-原来是动态页面/login 做成/login.html 伪装成静态页面,便于seo优化
-seo优化:
-https://www.cnblogs.com/liuqingzheng/articles/9509792.html
七.路由分发
1 有一个总路径,根路由,总路由负责做分发
2 每个app有自己的路由和视图函数的对应关系
3 使用:
-1 在根路由中配置
url(r'^app01',include(urls) ),
-2 在不同app中新建urls.py
urlpatterns = [
url(r'login/', views.login),
url(r'home/', views.home),
]
-3 http://127.0.0.1:8000/app01/login/ 先匹配app01,如果成功分发到app01的urls中继续匹配
八.反向解析
1 通过路由的别名,解析出路由的地址
url(r'^home/',views.home,name='home')
2 用在视图函数中:
url=reverse('home')
print(url)
3 用在模板中
{% url 'home' %}
4 有什么作用
-动态根据路由别名获得路径,一旦路径改变,不需要改其他代码
九.名称空间
1 路由做反向解析时,有同名路由,出现问题
2 在做路由分发时,给每个app的路径设置一个名称空间
3 使用步骤
-1在总路由中设置
url(r'^app01',include('app01.urls','名称空间的名字')),
-2用在视图函数中:
url=reverse('名称空间的名字:home')
print(url)
-3 模板文件中使用
{% url '名称空间的名字:meinv' %}