python之路_day107_django中url反向解析及数据库连接

一、url反向解析

  在正式介绍反向解析之前,我们首先介绍一下在django中的url参数,如下为我们url实例,其中name参数就是其别名,也就是我们接下来讲解的反向解析中所依靠的参数。

1、模板中反向解析

  在我们的前端页面上,如form表单,我们通常会指定提交的路径,但是以往我们都是将路径写死,这显然不是很合理,因为当url中的路径需要改变的时候,我们又需要逐一去更改页面。这样不合理。所以我们就要用到url的别名进行反向解析。

语法:
{% url 'url的别名' %}

   实例如下:

2、视图中反向解析

  在我们的视图中,如redirect,我们也会需要用到指定url情况,将路径写死很显然也不是很合理,我们也可通过反向解析的方式获得相应的路径,具体语法如下:

语法:
from django.core.urlresolvers import reverse
reverse('url别名')

   实例如下:

3、带参数的反向解析

  有如下形式的url别名,注意其特点是,对应的url中有正则表达式的分组参数,按照如上的方式进行反向解析时候,我们该怎样把它需要的参数传给他呢?

  对于这样的url,想通过反向解析获得相应的url时,必须要给其传符合正则表达式的参数,具体办法如下:

  模板代码中情况:

  视图代码中情况:

 

二、url名称空间

  假如,我们有两个app应用,通过路由分发,在两个app的urls文件中假如两个app中的url别名相同,则通过反向解析得到的结果有可能出现混乱,即会查找到另一个app中url别名对应的url路径,这显然不是我们想要的,造成的这样的原因是django在查找url别名是会从全局中查找。解决办法是在路由分发时指定名称空间参数namespace,如下所示:

  如上设置以后,在app应用按照如下方式方向解析时就不会出现问题:

三、django连接数据库

  我们知道在django中有通过数据迁移我们便有默认的sqlite数据库供我们使用,这是django自带的数据库,其实并不能满足我们的实际生产中的使用,这是因为在django的setting文件中进行如下的配置:

DATABASES = {
    'default': {
        'ENGINE': 'django.db.backends.sqlite3',
        'NAME': os.path.join(BASE_DIR, 'db.sqlite3'),
    }
}

  如果我们不想使用默认数据库,则我们可以重新在setting文件中配置此参数,设置成我们自己想要连接的数据库,如下为mysql数据库的配置方式,注意一点,django中不可以实现建立数据库,所以数据库需要我们在cmd中自行建好。

DATABASES = {

    'default': {

        'ENGINE': 'django.db.backends.mysql',
        'NAME': 'day107',                                     #你的数据库名称
        'USER': 'root',                                       #你的数据库用户名
        'PASSWORD': '',                                       #你的数据库密码
        'HOST': '',                                           #你的数据库主机,留空默认为localhost
        'PORT': '3306',                                       #你的数据库端口

    }
}

  除此,配置完上述以后,也不能完成数据库的迁移,主要原因和解决办法如下。如下更换跟换数据库的接口代码需要放在django项目或者应用的int.py 文件,保证在项目启动的时候完成自动加载。

 

posted @ 2018-01-25 16:07  骑猪走秀  阅读(250)  评论(0编辑  收藏  举报