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 路由参数
# 第一个参数是正则表达式
# 第二个参数是视图函数内存地址
# 第三个参数是个字典 {'name':lqz,'age':18},给视图函数传递默认值
# 第四个参数name,当前路由的别名,用作反向解析
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),
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 # 一般不加
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 在根路由中配置
# 路由分发
# 第一种方式
# url(r'^app01',include('app01.urls') ),
# 第二种方式
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中继续匹配
7 反向解析
1 通过路由的别名,解析出路由的地址
2 用在视图函数中:
url=reverse('home') # home就是路由的别名
print(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' %}