您的位置:首页 > 编程语言 > Python开发

python学习——在Python3.6环境下Django连接MySQL

2017-10-10 21:55 573 查看
环境:Django 1.11,Python 3.6,MySQL 5.7

Django默认的数据库是sqlite,要想改成mysql,除了需要在setting.py中将数据库改为:

DATABASES = {
'default': {
'ENGINE': 'django.db.backends.mysql',
'NAME': 'django_start',  #数据库名
'USER':'root',           #用户名
'PASSWORD':'root',       #密码
'HOST':'127.0.0.1',      #本机地址
'PORT':'3306',           #端口

}
}


还需要将Python与MySQL链接起来,通过mysqlclient

pip install mysqlclient


网上还有种方法,通过pymysql

pip install pymysql


但是需要在项目下的
__init__.py
中配置下:

import pymysql
pymysql.install_as_MySQLdb()


第一种方式成功连接,第二种未尝试过。

————————————————————————————————————

第二次添加:

在完成连接后,执行run manage.py Task

makemigrations


会弹出如下警告提示:

WARNINGS:
?: (1_8.W001) The standalone TEMPLATE_* settings were deprecated in Django 1.8 and the TEMPLATES dictionary takes precedence. You must put the values of the following settings into your default TEMPLATES dict: TEMPLATE_DIRS.


原因是版本的事情,Django 1.8之后的版本需要把TEMPLATES_DIRS中的内容放到TEMPLATES中。解决方法,在setting.py中修改:

TEMPLATES = [
{
'BACKEND': 'django.template.backends.django.DjangoTemplates',
'DIRS': [os.path.join(BASE_DIR, 'templates')],   #修改处
'APP_DIRS': True,
'OPTIONS': {
'context_processors': [
'django.template.context_processors.debug',
'django.template.context_processors.request',
'django.contrib.auth.context_processors.auth',
'django.contrib.messages.context_processors.messages',
],
},
},
]


并**删掉**setting.py中的最后一句:

TEMPLATE_DIRS = (os.path.join(BASE_DIR,  'templates'),)


即可。

———————————————————————————————————————————

第三次补充

当在linux系统上进行连接时,直接采用如下命令(ubuntu系统):

pip install mysqlclient


是会报错的。应该按照官方说法进行安装:

首先:

sudo apt-get install python-dev libmysqlclient-dev


其次:

sudo
ace9
apt-get install python3-dev


然后才是:

pip install mysqlclient


即可。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: