Django 使用pymysql報錯的解決方案


環境:
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即可。


免責聲明!

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



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