【问题标题】:Getting Exception when setting django with mysql-server使用 mysql-server 设置 django 时出现异常
【发布时间】:2014-03-06 01:53:09
【问题描述】:

首先我在我的 Ubuntu 机器上安装了 django

sudo apt-get install python-django

之后,我使用以下命令创建了我的第一个项目,并创建了一个名为“mysite”的目录。

django-admin.py startproject mysite

在这里,运行以下命令启动服务器,我在浏览器中检查,django 附带的最小服务器非常完美。

python manage.py runserver

然后,我安装了运行此命令的 mysql-server

sudo apt-get install mysql-server

之后,我在 mysql 中创建名为 'django_first' 的数据库。
并使用以下命令成功安装python模块mysqldb。

sudo apt-get install python-mysqldb

到目前为止,没有发生任何问题。但是一旦我在 settings.py 文件中设置了所有必要的字段后在目录中运行这个命令

DATABASES = {
    'default': {
        'ENGINE': 'django.db.backends.mysql',
        'NAME': 'django_first',
        'USER': 'root',
        'PASSWORD': 'password',
        'HOST': '',
        'PORT': '',
}

现在运行这个命令 python manage.py runserver

我收到以下错误:-

Traceback (most recent call last):
  File "manage.py", line 10, in <module>
    execute_from_command_line(sys.argv)
  File "/usr/local/lib/python2.7/site-packages/django/core/management/__init__.py", line  399, in execute_from_command_line
    utility.execute()
  File "/usr/local/lib/python2.7/site-packages/django/core/management/__init__.py", line 392, in execute
    self.fetch_command(subcommand).run_from_argv(self.argv)
  File "/usr/local/lib/python2.7/site-packages/django/core/management/base.py", line 242, in run_from_argv
    self.execute(*args, **options.__dict__)
  File "/usr/local/lib/python2.7/site-packages/django/core/management/base.py", line 280, in execute
    translation.activate('en-us')
  File "/usr/local/lib/python2.7/site-packages/django/utils/translation/__init__.py", line 130, in activate
    return _trans.activate(language)
  File "/usr/local/lib/python2.7/site-packages/django/utils/translation/trans_real.py", line 188, in activate
    _active.value = translation(language)
  File "/usr/local/lib/python2.7/site-packages/django/utils/translation/trans_real.py",     line 177, in translation
    default_translation = _fetch(settings.LANGUAGE_CODE)    
  File "/usr/local/lib/python2.7/site-packages/django/utils/translation/trans_real.py", line 159, in _fetch
    app = import_module(appname)
  File "/usr/local/lib/python2.7/site-packages/django/utils/importlib.py", line 40, in     import_module
    __import__(name)
  File "/usr/local/lib/python2.7/site-packages/django/contrib/admin/__init__.py", line 6, in <module>
    from django.contrib.admin.sites import AdminSite, site
  File "/usr/local/lib/python2.7/site-packages/django/contrib/admin/sites.py", line 4,     in <module>
    from django.contrib.admin.forms import AdminAuthenticationForm
  File "/usr/local/lib/python2.7/site-packages/django/contrib/admin/forms.py", line 6, in <module>
    from django.contrib.auth.forms import AuthenticationForm
  File "/usr/local/lib/python2.7/site-packages/django/contrib/auth/forms.py", line 17, in <module>
    from django.contrib.auth.models import User
  File "/usr/local/lib/python2.7/site-packages/django/contrib/auth/models.py", line 48, in <module>
    class Permission(models.Model):
  File "/usr/local/lib/python2.7/site-packages/django/db/models/base.py", line 96, in     __new__
    new_class.add_to_class('_meta', Options(meta, **kwargs))
  File "/usr/local/lib/python2.7/site-packages/django/db/models/base.py", line 264, in     add_to_class
    value.contribute_to_class(cls, name)
  File "/usr/local/lib/python2.7/site-packages/django/db/models/options.py", line 124, in contribute_to_class
    self.db_table = truncate_name(self.db_table, connection.ops.max_name_length())
  File "/usr/local/lib/python2.7/site-packages/django/db/__init__.py", line 34, in     __getattr__
    return getattr(connections[DEFAULT_DB_ALIAS], item)
  File "/usr/local/lib/python2.7/site-packages/django/db/utils.py", line 198, in     __getitem__
    backend = load_backend(db['ENGINE'])  
  File "/usr/local/lib/python2.7/site-packages/django/db/utils.py", line 113, in     load_backend
    return import_module('%s.base' % backend_name)
  File "/usr/local/lib/python2.7/site-packages/django/utils/importlib.py", line 40, in     import_module
    __import__(name)
  File "/usr/local/lib/python2.7/site-packages/django/db/backends/mysql/base.py", line     17, in <module>
    raise ImproperlyConfigured("Error loading MySQLdb module: %s" % e)
django.core.exceptions.ImproperlyConfigured: Error loading MySQLdb module: No module     named MySQLdb`

似乎是未安装 mysqldb 模块的问题,但不完全是因为我为此重新运行安装命令。

对此有什么想法吗?

【问题讨论】:

  • 在 python 控制台(不是 django shell)中尝试import MySQLdb,会发生什么?
  • "ImportError: No module named MySQLdb" 是我做import MySQLdb时得到的结果@
  • 哦,等等,没关系,我看到了问题。

标签: python mysql django python-2.7 ubuntu


【解决方案1】:

检查是否安装了libmysqlclient-dev? 如果没有安装,请尝试安装

sudo apt-get install libmysqlclient-dev

希望这能解决您的问题

【讨论】:

    【解决方案2】:

    MySQLdb 只是连接到 MySQL 的模块,但它是名为 MySQL-Python 的更大包的一部分。做吧:

    pip install MySQL-python
    

    它应该处理所有事情(您可能需要sudo 那个命令)。事实上,我可能会建议你这样做:

    pip install MySQL-python --upgrade
    

    为了确保它安装最新版本。如果这没有任何改变,请关注these instructions 以确保您获得最新版本和所有必需的依赖项

    附言一般来说,总是更喜欢pip 而不是apt-get 来安装python 包,因为它更新得更频繁。例如,您使用apt-get 方法安装的django 版本很可能是一个非常旧的版本。要解决此问题,请删除站点包中的 django 文件夹并执行以下操作:

    pip install django==1.6.2 #this is the latest version
    

    【讨论】:

    • 感谢@yuvi 的建议。
    • 正如您所说,这是 Mysqldb 的问题,但不仅仅是升级 MySQL-python 。我仍然面临导入错误。所以我只是在我的系统上构建了 MySQL 源并完成了它
    • 听起来很痛苦,但很高兴听到它得到了整理
    【解决方案3】:

    在尝试了上面给出的所有建议之后,我设法查明了没有链接到 MySQLdb 模块的问题。

    我决定从这里构建代码并安装源代码。 http://sourceforge.net/projects/mysql-python/

    在构建它之前,您需要确保满足以下先决条件:

    1. gcc 编译器
    2. MySQL 服务器。我使用的是 MySQL 社区服务器版本

    同时运行这些命令:

    sudo apt-get install python-setuptools python-dev libmysqlclient15-dev
    

    如果您在使用 mysql_config 时遇到错误,请不要忘记修复 PATH env。变量

    export PATH=$PATH:/usr/local/mysql/bin
    

    现在我们可以编译代码了:-

    sudo python setup.py build
    sudo python setup.py install
    

    现在打开你的 python 命令行并导入新的 MySQLdb 模块

    $> python
    >>> import MySQLdb
    

    您应该不会看到任何导入错误。

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2013-09-02
      • 2021-06-29
      • 2017-09-21
      • 2018-10-06
      相关资源
      最近更新 更多