django基于python3组合,数据库连接遇到的坑

2018-07-14  本文已影响0人  wowshiwoniu

看到网上很多教程都在使用python3,周末在家一顿折腾,为了不影响原来的项目,在电脑上新装了一套python3环境,共存,使用virtualenv进行隔折腾。上一篇讲述了折腾的历程,只能说更新换代太快,防不胜防哈。

好了,废话不多说,首先利用python3创建虚拟环境

mkvirtualenv -p python3 myproject

mkvirtualenv 这个命令是我安装了 virtualenvwrapper,这个包对virtualenv进一步的封装,使用更加方便,有兴趣的小伙伴可以去了解一下,不过最近新推出了一个更牛逼的包pyenv,功能强大到可以管理python版本。

主要区别:
pyenv 通过系统修改环境变量来实现 Python 不同版本的切换。而 virtualenv 通过将 Python 包安装到一个目录来作为Python 包虚拟环境,通过切换目录来实现不同包环境间的切换。

主题不在这里,就不多扯了,有兴趣的小伙伴可以去了解下。

安装完虚拟环境之后,首先,需要安装必须的依赖库。

目前可以先把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。

上一篇下一篇

猜你喜欢

热点阅读