在Django 2.2 + python 3.7环境下,使用MySQL作为数据库引擎,执行makemigrations会出现AttributeError: 'str' object has no attribute 'decode' 错误. 初步推断是因为使用PyMySQL代替mysqlclient的原因,而django本身的代码都是针对mysqlclient写的.PyMySQL这里传入的会是一个str类型,而str类型没有decode方法所以报错.
在网上找到了一个暂时的解决方法如下:
1. 找到django安装的位置并找到下面的python文件
/python3.7/site-packages/django/db/backends/mysql/operations.py
2. 在146行找到如下图的这个判断语句, 注释掉146和147行.
3. 问题暂时解决.

Django MySQL makemigrations 错误修复

在Django2.2与Python3.7环境下,使用MySQL数据库时,执行makemigrations命令出现AttributeError:'str'objecthasnoattribute'decode'错误。此错误源于PyMySQL替换mysqlclient导致的数据类型不匹配。本文提供了一个临时解决方案,通过修改Django源代码中的特定判断语句来规避此问题。
702

被折叠的 条评论
为什么被折叠?



