django基于python3组合,数据库连接遇到的坑
看到网上很多教程都在使用python3,周末在家一顿折腾,为了不影响原来的项目,在电脑上新装了一套python3环境,共存,使用virtualenv进行隔折腾。上一篇讲述了折腾的历程,只能说更新换代太快,防不胜防哈。
好了,废话不多说,首先利用python3创建虚拟环境
mkvirtualenv -p python3 myproject
mkvirtualenv 这个命令是我安装了 virtualenvwrapper
,这个包对virtualenv进一步的封装,使用更加方便,有兴趣的小伙伴可以去了解一下,不过最近新推出了一个更牛逼的包pyenv
,功能强大到可以管理python版本。
主要区别:
pyenv 通过系统修改环境变量来实现 Python 不同版本的切换。而 virtualenv 通过将 Python 包安装到一个目录来作为Python 包虚拟环境,通过切换目录来实现不同包环境间的切换。
主题不在这里,就不多扯了,有兴趣的小伙伴可以去了解下。
安装完虚拟环境之后,首先,需要安装必须的依赖库。
- Django
pip install Django==1.10.8
- MySQL-python (python不支持)
问题来了,pip install MySQL-python
报错了,刚开始以为权限不够,后来加了sudo还是不行,google了一把,原理python3不支持了,推荐使用pymysql这个库,好吧,那就安装这个吧 - pymysql
pip install pymysql
目前可以先把django项目跑起来了,开心的创建了一个django测试demo,没跑起来,抛异常了,不支持MySQLdb,异常信息:django.core.exceptions.ImproperlyConfigured: Error loading MySQLdb module: No module named 'MySQLdb'
django默认使用的MySQLdb连接数据库,这个怎么解决,想来肯定是有办法的,查了下,可能理解能力差,网上说是在项目的init.py文件下添加两行代码
import pymysql
pymysql.install_as_MySQLdb()
项目下这么多init.py文件,怎么一个一个去添加啊,不应该是这样啊,肯定是自己理解的有问题,想了下,这里应该说的是setting.py文件所在的目录,创建django的时候,指定的项目目录下的init.py文件,试了一下,果然如此。
举个栗子:
创建一个django web项目,我们首先要执行下面这个命令:
django-admin.py startproject myproject
这里的myproject,我们需要添加的两行pymysql代码,就是在它下面的init.py文件内。
好了,这样就解决了数据库连接问题,这里我使用的是mysql,所以我的配置文件也是针对mysql的,数据库setting配置:
DATABASES = {
'default': {
'ENGINE': 'django.db.backends.mysql', # 数据库引擎
'NAME': 'polls', # 你要存储数据的库名,事先要创建之
'USER': 'root', # 数据库用户名
'PASSWORD': '111111', # 密码
'HOST': 'localhost', # 主机
'PORT': '3306', # 数据库使用的端口
}
}
注意,上面的数据库配置属性:'ENGINE',这里使用的是'django.db.backends.mysql'。
好了,问题解决了。
今天看到有对python连接mysql数据库方式的介绍,传送门,然后查了下,pymysql是原生的纯安卓编写,速度上肯定会有所牺牲,django文档中也没有相关介绍,推荐的是mysqlclient
mysqlclient-python is much faster than PyMySQL.
When to use PyMySQL is:
You can't use libmysqlclient for some reason
You want to use monkeypatched socket of gevent or eventlet
You wan't to hack mysql protocol
mysqlclient是比pymysql速度快的,但是pymysql是原生python编写,兼容是最好的,因此可以很好的和gevent 框架结合,如果你的项目里用了gevent那你就只能用pymysql 了。或者你由于某些原因无法使用mysqlclient。