首页 > 数据库技术 > 详细

Django 使用pymysql报错的解决方案

时间:2019-11-10 10:58:08      阅读:78      评论:0      收藏:0      [点我收藏+]

环境:
Ubuntu18.04
mysql:8.0
python: 3.6.8
django: 2.2.6
pymysql: 0.9.3

  1. 安装pymysql
    pip install pymysql

  2. 将pymysql引入到django

    在和项目目录一样名字的包下面的__init__.py文件中写入以下代码:

    import pymysql
    
    pymysql.install_as_MySQLdb()
  3. 在django中配置mysql,之后启动django服务,发现报错如下:

    File "/home/www/.local/share/virtualenvs/EduScore-UXZMOCwv/lib/python3.6/site-packages/django/db/backends/mysql/base.py", line 36, in <module>
        raise ImproperlyConfigured('mysqlclient 1.3.13 or newer is required; you have %s.' % Database.__version__)
    django.core.exceptions.ImproperlyConfigured: mysqlclient 1.3.13 or newer is required; you have 0.9.3.

    解决方法:
    使用vim打开 /home/www/.local/share/virtualenvs/EduScore-UXZMOCwv/lib/python3.6/site-packages/django/db/backends/mysql/base.py 文件,将以下代码注释掉

    #if version < (1, 3, 13):
    #    raise ImproperlyConfigured('mysqlclient 1.3.13 or newer is required; you have %s.' % Database.__version__)
  4. 启动django server 发现还是报错,报错信息为:

    AttributeError: 'str' object has no attribute 'decode'

    解决方法:

    找到对应文件,将报错行的decode改为encode即可。

Django 使用pymysql报错的解决方案

原文:https://www.cnblogs.com/finlu/p/11829005.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!