在 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 shellpython 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简译

在 Django 1.11 中启用 CORS

升级到 django 1.11 多对多列未找到

在视图中使用全文搜索 + GIN (Django 1.11 )

Django 1.11 使用来自应用程序的模板作为管理模板

Django 1.11:在 url 中的查询参数中浮动