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-dev
和python3-dev
已经安装了吗?
Wtower,因为我现在这个库适用于 debian/ubuntu。我找到了解决方案 - 添加到问题的正文中。
【参考方案1】:
试试这个;这解决了我的问题
pip install MySQL-python
【讨论】:
MySQL-python 不支持 Python3 :( pypi.python.org/pypi/MySQL-python/1.2.5【参考方案2】:在 Python3 中,我必须在需求中添加 mysqlclient
,MySQL-python
不支持 Python3。
【讨论】:
以上是关于Django 错误:没有名为 _mysql 的模块的主要内容,如果未能解决你的问题,请参考以下文章
Google App Engine SDK:配置不当:加载 MySQLdb 模块时出错:没有名为 _mysql 的模块
错误:'没有名为'django.core.urlresolvers'的模块