美文网首页
django基于python3组合,数据库连接遇到的坑

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

作者: wowshiwoniu | 来源:发表于2018-07-14 13:31 被阅读0次

    看到网上很多教程都在使用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。

    相关文章

      网友评论

          本文标题:django基于python3组合,数据库连接遇到的坑

          本文链接:https://www.haomeiwen.com/subject/uixypftx.html