Django 错误:没有名为 _mysql 的模块

Posted

技术标签:

【中文标题】Django 错误:没有名为 _mysql 的模块【英文标题】:Django error: No module named _mysql 【发布时间】:2016-03-20 21:50:15 【问题描述】:

我正在将我的应用程序从默认 django 的 sqlitedb 迁移到 prod mariadb 数据库中。有python3.3 + centos 7 + django 1.8 + apache环境。 在 sqlite 上一切正常,但是在迁移之后我在 apache 重新启动后出现这样的错误:

Traceback (most recent call last):
  File "/usr/local/mainproject/mysite/mysite/wsgi.py", line 23, in <module>
  application = get_wsgi_application()
  File "/usr/local/lib/python3.3/site-packages/django/core/wsgi.py", line 14, in get_wsgi_application
django.setup()
  File "/usr/local/lib/python3.3/site-packages/django/__init__.py", line 18, in setup
    apps.populate(settings.INSTALLED_APPS)
  File "/usr/local/lib/python3.3/site-packages/django/apps/registry.py", line 108, in populate
app_config.import_models(all_models)
  File "/usr/local/lib/python3.3/site-packages/django/apps/config.py", line 198, in import_models
self.models_module = import_module(models_module_name)
  File "/usr/lib64/python2.7/importlib/__init__.py", line 37, in import_module
__import__(name)
  File "/usr/local/lib/python3.3/site-packages/django/contrib/auth/models.py", line 41, in <module>
class Permission(models.Model):
  File "/usr/local/lib/python3.3/site-packages/django/db/models/base.py", line 139, in __new__
new_class.add_to_class('_meta', Options(meta, **kwargs))
  File "/usr/local/lib/python3.3/site-packages/django/db/models/base.py", line 324, in add_to_class
value.contribute_to_class(cls, name)
  File "/usr/local/lib/python3.3/site-packages/django/db/models/options.py", line 250, in contribute_to_class
self.db_table = truncate_name(self.db_table, connection.ops.max_name_length())
  File "/usr/local/lib/python3.3/site-packages/django/db/__init__.py", line 36, in __getattr__
return getattr(connections[DEFAULT_DB_ALIAS], item)
  File "/usr/local/lib/python3.3/site-packages/django/db/utils.py", line 240, in __getitem__
backend = load_backend(db['ENGINE'])
  File "/usr/local/lib/python3.3/site-packages/django/db/utils.py", line 111, in load_backend
return import_module('%s.base' % backend_name)
  File "/usr/lib64/python2.7/importlib/__init__.py", line 37, in import_module
__import__(name)
  File "/usr/local/lib/python3.3/site-packages/django/db/backends/mysql/base.py", line 27, in <module>
raise ImproperlyConfigured("Error loading MySQLdb module: %s" % e)
ImproperlyConfigured: Error loading MySQLdb module: No module named _mysql

我已经安装了 mysqlclient,正如这里所说的 https://docs.djangoproject.com/en/1.8/ref/databases/#mysql-db-api-drivers。 比我做的 manage.py syncdb 和它已经成功完成。我检查了数据库结构,一切正常 - 所有数据都已迁移。 但是我的应用启动时仍然出现这样的错误。

解决办法是:使用非官方的libshttps://github.com/nakagami/django-cymysql/用django安装和配置很容易:

$ pip install cymysql
$ pip install django-cymysql

不仅仅是将此引擎添加到 django 的 settings.py 中:

DATABASES = 
'default': 
    'ENGINE': 'mysql_cymysql',
    'NAME': 'some_what_database',
    'HOST': ...,
    'USER': ...,
    'PASSWORD': ...,
   

【问题讨论】:

你能确定libmysqlclient-devpython3-dev已经安装了吗? Wtower,因为我现在这个库适用于 debian/ubuntu。我找到了解决方案 - 添加到问题的正文中。 【参考方案1】:

试试这个;这解决了我的问题

pip install MySQL-python

【讨论】:

MySQL-python 不支持 Python3 :( pypi.python.org/pypi/MySQL-python/1.2.5【参考方案2】:

在 Python3 中,我必须在需求中添加 mysqlclientMySQL-python 不支持 Python3。

【讨论】:

以上是关于Django 错误:没有名为 _mysql 的模块的主要内容,如果未能解决你的问题,请参考以下文章

Google App Engine SDK:配置不当:加载 MySQLdb 模块时出错:没有名为 _mysql 的模块

导入错误:没有名为“scipy._lib”的模块

heroku 没有名为 _sqlite3 的模块

错误:'没有名为'django.core.urlresolvers'的模块

ImportError:没有名为 redis_cache 的模块

Django - 没有名为 _sqlite3 的模块