报错信息如下:
(venv) F:\python\test_project\Coconut>python manage.py runserver
Watching for file changes with StatReloader
Performing system checks...
System check identified no issues (0 silenced).
Exception in thread django-main-thread:
Traceback (most recent call last):
File "C:\Users\Administrator\AppData\Local\Programs\Python\Python36\lib\threading.py", line 916, in _bootstrap_inner
self.run()
File "C:\Users\Administrator\AppData\Local\Programs\Python\Python36\lib\threading.py", line 864, in run
self._target(*self._args, **self._kwargs)
File "F:\python\PYproject\venv\lib\site-packages\django\utils\autoreload.py", line 54, in wrapper
fn(*args, **kwargs)
File "F:\python\PYproject\venv\lib\site-packages\django\core\management\commands\runserver.py", line 120, in inner_run
self.check_migrations()
File "F:\python\PYproject\venv\lib\site-packages\django\core\management\base.py", line 453, in check_migrations
executor = MigrationExecutor(connections[DEFAULT_DB_ALIAS])
File "F:\python\PYproject\venv\lib\site-packages\django\db\migrations\executor.py", line 18, in __init__
self.loader = MigrationLoader(self.connection)
File "F:\python\PYproject\venv\lib\site-packages\django\db\migrations\loader.py", line 49, in __init__
self.build_graph()
File "F:\python\PYproject\venv\lib\site-packages\django\db\migrations\loader.py", line 212, in build_graph
self.applied_migrations = recorder.applied_migrations()
File "F:\python\PYproject\venv\lib\site-packages\django\db\migrations\recorder.py", line 73, in applied_migrations
if self.has_table():
File "F:\python\PYproject\venv\lib\site-packages\django\db\migrations\recorder.py", line 56, in has_table
return self.Migration._meta.db_table in self.connection.introspection.table_names(self.connection.cursor())
File "F:\python\PYproject\venv\lib\site-packages\django\db\backends\base\base.py", line 256, in cursor
return self._cursor()
File "F:\python\PYproject\venv\lib\site-packages\django\db\backends\base\base.py", line 233, in _cursor
self.ensure_connection()
File "F:\python\PYproject\venv\lib\site-packages\django\db\backends\base\base.py", line 217, in ensure_connection
self.connect()
File "F:\python\PYproject\venv\lib\site-packages\django\db\backends\base\base.py", line 197, in connect
self.init_connection_state()
File "F:\python\PYproject\venv\lib\site-packages\django\db\backends\mysql\base.py", line 231, in init_connection_state
if self.features.is_sql_auto_is_null_enabled:
File "F:\python\PYproject\venv\lib\site-packages\django\utils\functional.py", line 80, in __get__
res = instance.__dict__[self.name] = self.func(instance)
File "F:\python\PYproject\venv\lib\site-packages\django\db\backends\mysql\features.py", line 82, in is_sql_auto_is_null_enabled
cursor.execute('SELECT @@SQL_AUTO_IS_NULL')
File "F:\python\PYproject\venv\lib\site-packages\django\db\backends\utils.py", line 103, in execute
sql = self.db.ops.last_executed_query(self.cursor, sql, params)
File "F:\python\PYproject\venv\lib\site-packages\django\db\backends\mysql\operations.py", line 146, in last_executed_query
query = query.decode(errors='replace')
AttributeError: 'str' object has no attribute 'decode'
报错原因:
python与mysql交互时,str编码的问题
解决办法:
点击“…\operations.py”文件,
修改
query = query.decode(errors='replace')
为
query = query.encode(errors='replace')
注意:
因为要修改源码,所以最好把源码注释掉再加一行,把decode改为encode。
如有不足,欢迎指正