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中将数据库改为:
还需要将Python与MySQL链接起来,通过mysqlclient:
网上还有种方法,通过pymysql:
但是需要在项目下的
第一种方式成功连接,第二种未尝试过。
————————————————————————————————————
第二次添加:
在完成连接后,执行run manage.py Task
会弹出如下警告提示:
原因是版本的事情,Django 1.8之后的版本需要把TEMPLATES_DIRS中的内容放到TEMPLATES中。解决方法,在setting.py中修改:
并**删掉**setting.py中的最后一句:
即可。
———————————————————————————————————————————
第三次补充
当在linux系统上进行连接时,直接采用如下命令(ubuntu系统):
是会报错的。应该按照官方说法进行安装:
首先:
其次:
然后才是:
即可。
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
即可。
相关文章推荐
- Python3环境下django连接mysql报错:No module named 'MySQLdb'
- python学习之--Django--连接数据库mysql创建model
- python+Django+pycharm+mysql 环境搭建及第一个项目学习笔记
- No module named 'MySQLdb' python3.6 + django 1.10 + mysql 无法连接
- python,django,mysql学习之环境安装配置
- CentOS + Python3.6+ Django2.0 + uwsgi + nginx + mysql web发布环境搭建
- python django MySQLdb 连接 mysql 5.5 中文乱码问题的解决
- Mac下搭建Django+XAMPP(Mysql+Apache)+Python网站开发环境
- Debian环境 Python + Django + Nginx + uWSGI + MySQL 配置
- linux下使用pydev eclipse Mysql-python 搭建django开发环境
- Apache+MySQL+Python+Django在Windows下环境搭建指南
- Python 学习入门(4)—— 连接MySQL
- Eclipse+PyDev+Django+Mysql搭建Python web开发环境
- Eclipse+PyDev+Django+Mysql搭建Python web开发环境
- Python 学习入门(4)—— 连接MySQL
- Python web框架Django学习(1)——在win7 64bit下配置开发环境Django:一个可以使Web开发工作愉快并且高效的Web开发框架。 使用Django,使你能够以最小的代价构建和
- Centos5.5搭建nginx + python + django +memcached+ mysql +fastcgi 环境
- 搭建nginx + python + django +memcached+ mysql +fastcgi 环境
- Python_python/django连接mysql安装与配置
- python-django学习(一)搭建环境