django2.2/mysql ImproperlyConfigured: mysqlclient 1.3.13 or newer is required; you have 0.9.3


報錯環境 python=3.6,django=2.2,PyMySQL=0.9.3
……
django.core.exceptions.ImproperlyConfigured: mysqlclient 1.3.13 or newer is required; you have 0.9.3.

  

解決方法:
Django連接MySQL時默認使用MySQLdb驅動,但MySQLdb不支持Python3,因此這里將MySQL驅動設置為pymysql,使用 pip install pymysql 進行安裝,然后在工程文件__init__.py添加以下代碼即可。

#安裝pymysql

pip install pymysql

#__init__.py
import pymysql
pymysql.install_as_MySQLdb()

第一種:
django降到2.1.4版本就OK了

 

第二種(仍使用django 2.2版本):

1、#找到Python環境下 django包,並進入到backends下的mysql文件夾
cd /opt/anaconda3/envs/envAGC_Mini/lib/python3.6/site-packages/django/db/backends/mysql


2、# 找到base.py文件,注釋掉 base.py 中如下部分(35/36行)
if version < (1, 3, 3):
raise ImproperlyConfigured("mysqlclient 1.3.3 or newer is required; you have %s" % Database.__version__)

此時仍會會報錯,報錯信息如下:

AttributeError: ‘str’ object has no attribute ‘decode’

#找到operations.py文件(46行,版本不同行數不同哈~自個兒find一下),將decode改為encode

if query is not None:
query = query.decode(errors='replace')
return query
#改為
if query is not None:
query = query.encode(errors='replace')
return query

 
原文:https://blog.csdn.net/weixin_33127753/article/details/89100552


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM