快上网专注成都网站设计 成都网站制作 成都网站建设
成都网站建设公司服务热线:028-86922220

网站建设知识

十年网站开发经验 + 多家企业客户 + 靠谱的建站团队

量身定制 + 运营维护+专业推广+无忧售后,网站问题一站解决

Django中要怎么样连接Mysql数据库-创新互联

创新互联www.cdcxhl.cn八线动态BGP香港云服务器提供商,新人活动买多久送多久,划算不套路!

创新互联建站提供高防物理服务器租用、云服务器、香港服务器、服务器托管德阳

这篇文章主要介绍了Django中要怎么样连接Mysql数据库,具有一定借鉴价值,需要的朋友可以参考下。希望大家阅读完这篇文章后大有收获。下面让小编带着大家一起了解一下。

处理用户注册请求、Django连接MysqL数据库相关配置、数据库迁移命令:

my_Dproject/app01/views.py    在views函数文件中添加register函数,来处理用户注册的请求。

Django中要怎么样连接Mysql数据库

Tips:获取get请求数据的方式跟POST请求完全一样。

获取到用户注册信息,接下来需要连接数据库,拿到数据库的用户数据进行验证,注册的成功与否。

Django连接MySQL数据库的方法:

my_Dproject/my_Dproject/settings.py    继续回到settings配置文件中,来配置Django连接MySQL。

Django中要怎么样连接Mysql数据库

DATABASES = {
    'default': {
        'ENGINE': 'django.db.backends.mysql',
        'NAME': 'my_Dproject',
        'HOST': '127.0.0.1',
        'PORT': 3306,
        'USER': 'root',
        'PASSWORD': '123',
    }
}

Django中要怎么样连接Mysql数据库

还没完,接着需要去项目的init文件中添加相关信息,告诉Django用MySQL数据库连接数据库就行。

my_Dproject/my_Dproject/__Init__.py中添加下面信息:

import pymysql
pymysql.install_as_MySQLdb()

(这里需要注意:__init__.py文件还在app01文件中有,也可以在app01中的init文件中添加,效果一样。)

配置添加Django中orm的models文件

重点:Django的orm不能自动帮我们创建数据库,但是可以自动帮我们创建表,同时一个Django项目就使用一个数据库。

my_Dproject/app01/models.py  中添加映射表的相关类。

这里我们需要用到用户数据表,所以创建一张User类来映射MySQL数据库中的user用户表。

class User(models.Model):
    id = models.AutoField(primary_key=True)
    name = models.CharField(max_length=32)
    password = models.CharField(max_length=16)

Django中要怎么样连接Mysql数据库

映射表的类创建完毕后,需要进行关键的2步【数据库迁移命令】操作,才能创建出user表:

第一步:将数据库变动记录记录到一个文件中:

在pycharm自带的Terminal命令行中输入:

python3 manage.py makemigrations

第二步:将数据库变动同步到数据库中:

python3 manage.py migrate

Django中要怎么样连接Mysql数据库

Django中要怎么样连接Mysql数据库

重点:

以后只要涉及到数据库的一丝变动(这里主要说的是表结构),要想让变动生效一定要执行这2步数据库迁移(同步)命令!!!

这里提一个小点:我们在测试时候如果遇到下面这种情况:

Django中要怎么样连接Mysql数据库

解决办法是:在settings.py文件中注释掉一行代码:

Django中要怎么样连接Mysql数据库

感谢你能够认真阅读完这篇文章,希望小编分享Django中要怎么样连接Mysql数据库内容对大家有帮助,同时也希望大家多多支持创新互联,关注创新互联-成都网站建设公司行业资讯频道,遇到问题就找创新互联,详细的解决方法等着你来学习!


网页名称:Django中要怎么样连接Mysql数据库-创新互联
文章起源:http://6mz.cn/article/gesje.html

其他资讯