在 Django 1.11 中使用 MySQL 连接器/Python 时出错
Posted
技术标签:
【中文标题】在 Django 1.11 中使用 MySQL 连接器/Python 时出错【英文标题】:Error using MySQL Connector/Python with Django 1.11 【发布时间】:2017-10-23 02:32:45 【问题描述】:我已经通过 cmd 中的以下命令创建了 Django 项目:
django-admin.py startproject database
然后我编辑 settings.py 如下:
DATABASES =
'default':
'ENGINE':'mysql.connector.django',
'NAME' : 'music',
'USER':'python',
'PASSWORD':'123654789',
'HOST':'127.0.0.2',
'OPTIONS':
'automatic':True,
当我运行 python manage.py shell
或 python manage.py runserver
我有错误
type Error None type object is not callable
我正在使用:
Python version 3.4.3,
Os win8,
Django version 1.11,
mysql 5.7,
MySQL Connector/Python.
错误:
Traceback (most recent call last):
File "C:\Users\Bibek Ghimire\djcode\database\manage.py", line 22, in <module>
execute_from_command_line(sys.argv)
File "C:\Python34\lib\site-packages\django\core\management\__init__.py", line 363, in execute_from_command_line
utility.execute()
File "C:\Python34\lib\site-packages\django\core\management\__init__.py", line 337, in execute
django.setup()
File "C:\Python34\lib\site-packages\django\__init__.py", line 27, in setup
apps.populate(settings.INSTALLED_APPS)
File "C:\Python34\lib\site-packages\django\apps\registry.py", line 108, in populate
app_config.import_models()
File "C:\Python34\lib\site-packages\django\apps\config.py", line 202, in import_models
self.models_module = import_module(models_module_name)
File "C:\Python34\lib\importlib\__init__.py", line 109, in import_module
return _bootstrap._gcd_import(name[level:], package, level)
File "<frozen importlib._bootstrap>", line 2254, in _gcd_import
File "<frozen importlib._bootstrap>", line 2237, in _find_and_load
File "<frozen importlib._bootstrap>", line 2226, in _find_and_load_unlocked
File "<frozen importlib._bootstrap>", line 1200, in _load_unlocked
File "<frozen importlib._bootstrap>", line 1129, in _exec
File "<frozen importlib._bootstrap>", line 1471, in exec_module
File "<frozen importlib._bootstrap>", line 321, in _call_with_frames_removed
File "C:\Python34\lib\site-packages\django\contrib\auth\models.py", line 4, in <module>
from django.contrib.auth.base_user import AbstractBaseUser, BaseUserManager
File "C:\Python34\lib\site-packages\django\contrib\auth\base_user.py", line 52, in <module>
class AbstractBaseUser(models.Model):
File "C:\Python34\lib\site-packages\django\db\models\base.py", line 124, in __new__
new_class.add_to_class('_meta', Options(meta, app_label))
File "C:\Python34\lib\site-packages\django\db\models\base.py", line 330, in add_to_class
value.contribute_to_class(cls, name)
File "C:\Python34\lib\site-packages\django\db\models\options.py", line 214, in contribute_to_class
self.db_table = truncate_name(self.db_table, connection.ops.max_name_length())
File "C:\Python34\lib\site-packages\django\db\__init__.py", line 33, in __getattr__
return getattr(connections[DEFAULT_DB_ALIAS], item)
File "C:\Python34\lib\site-packages\django\db\utils.py", line 212, in __getitem__
conn = backend.DatabaseWrapper(db, alias)
File "C:\Python34\lib\site-packages\mysql\connector\django\base.py", line 336, in __init__
super(DatabaseWrapper, self).__init__(*args, **kwargs)
File "C:\Python34\lib\site-packages\django\db\backends\base\base.py", line 96, in __init__
self.client = self.client_class(self)
TypeError: 'NoneType' object is not callable
【问题讨论】:
【参考方案1】:我遇到了同样的问题,并且使用了完全相同的配置。所以。首先我尝试了 mysqlclient 但它不起作用所以我安装了 mysql-connector==2.1.6 令人惊讶的是它也不能与 Django1.11 一起使用所以我在 google 上做了一些研究并找到了解决方案。
如果 >>> 你是facebook用户登录并访问https://www.facebook.com/groups/python.django/permalink/1657026527681920/
其他 >>>
1) 激活你的 virtualenv。
2) pip3 安装 mysql-connector==2.1.6
3) 访问:https://github.com/mysql/mysql-connector-python/tree/master/lib/mysql/connector/django ...并下载 django1.11 的 base.py。
4) 现在,转到您的环境的 lib/python(version)/site-packages/mysql/connector/django 并将 base.py 替换为之前下载的 base.py。
【讨论】:
【参考方案2】:在https://github.com/multiplay/mysql-connector-python 有一个 mysql 连接器的补丁版本,用于兼容 Django 1.11。
【讨论】:
【参考方案3】:MySQL 连接器/Python 并不总是支持最新版本的 Django。您的回溯看起来类似于 this issue。
我建议你尝试改用mysqlclient
,也就是recommended choice for using MySQL with Django。
【讨论】:
我厌倦了尝试安装mysqlclient(也推荐在django教程上)以下版本:python3.4 win8和mysql5.7,亲爱的先生,请给我一些建议。 在Windows上安装mysqlclient恐怕忍不住了。使用 Python 3.5 或 Python 3.6 可能会更幸运,因为有可用的***。或者,您可以尝试使用 MySQL 连接器/Python 的早期版本的 Django(目前都支持 Django 1.8 LTS 和 1.10),或者使用不同的数据库后端,例如sqlite. 我已经下载了 python3.6 我应该删除我的旧 python3.4 。如果不是,那么将使用 pip install package 安装哪个版本的 python。 您可以在 Windows 上同时安装 Python 3.4 和 3.6。pip
使用哪个版本取决于您的路径。我对此无能为力,因为我不熟悉 Windows,而且它已经脱离了这个问题的主题。【参考方案4】:
在您的数据库设置中替换:
'ENGINE':'mysql.connector.django',
与:
'ENGINE':'django.db.backends.mysql'
【讨论】:
更换数据库引擎时记得安装mysqlclient
!
我厌倦了尝试安装 MySQLdb 和 mysqlclient。当我尝试 pip install mysqlclient 总是以错误结束:无法打开包含文件 myconfig.h 。我在互联网上遵循了太多的指令,我发现最好的解决方案是使用 mysql 连接器访问 mysql 数据库并且工作正常。它不仅适用于 django。如果您有任何完整的解决方案,请告诉我。我有 win8(64 位)、python3.4.3、django 1.11 和 pyconnector。以上是关于在 Django 1.11 中使用 MySQL 连接器/Python 时出错的主要内容,如果未能解决你的问题,请参考以下文章
Two Scoops of Django 1.11 章节2.1简译