Django启动时mysqlclient报错版本低于1.3.13

启动Django时报错,mysqlclient版本低于1.3.13:

File "C:\Users\wurij\AppData\Local\Programs\Python\Python37\lib\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.

  

解决思路及过程如下,解决办法可直接查看步骤5

1.一开始怀疑是公司内网的pip源中的mysqlclient版本低~

2.通过pip list查看mysqlclient包的版本是1.4.6,并不低啊!

3.找到报错的base.py文件,将其中检测版本的两行拿出来,在当前的Python环境中执行,结果是版本也并不低于1.3.13,真是见鬼了~

import MySQLdb as Database
version = Database.version_info
print(version, version < (1, 3, 13))
#(1, 4, 6, 'final', 0) False

4.想起来之前有用过pymysql包,是不是这货引起的冲突,于是将pymysql卸载,同时清理pymysql在Django项目__init__.py的两行代码,报错不在了!

5.原因是之前使用了pymysql,在Django主app目录(有settings.py的那个目录)下的__init__.py中添加了如下两行代码

import pymysql
pymysql.install_as_MySQLdb()

这两行代码覆盖了base.py中的Database变量,版本判断函数检测的是PyMySql的版本

于是pip list查看PyMySql的版本,巧了!也是0.9.3,问题总算是水落石出了!

 

顺便说几句:

  1. 网上很多人用pymysql替代mysqlclient,说是mysqlclient很难装,其实也还好(可参考我的上一篇随笔)。
  2. 如果你是用的pymysql替换mysqlclient,出现前面版本的报错,需要将base.py中的“if version < (1, 3, 13):”及后面一行注释掉。
  3. 如果你用的pymysql替换mysqlclient,Django开启debug模式后,启动时会报一个decode的错,解决办法是找到报错的那一行将decode方法改成encode就行了。

感觉使用pymysql替换mysqlclient的破坏性太强了,都要直接修改django的源码了(当然也可以自己修改settings中mysql的bakends到自己的目录),还不如直接使用mysqlclient(毕竟是Django官方推荐的)

 

上一篇:Django使用mysql数据库


下一篇:pymysql查询sql时中文报错,ValueError: unsupported format character '?' (0x5927) at index 134