zoukankan      html  css  js  c++  java
  • 在执行migrate的时候出现问题(错误见末尾): django.db.utils.OperationalError: (1045, "Access denied for user ‘ODBC‘@‘localho st‘ (using password: YES)")

    Python框架之Django的数据库

    在执行migrate的时候出现问题(错误见末尾)

    django.db.utils.OperationalError: (1045, "Access denied for user ‘ODBC‘@‘localho

    st‘ (using password: YES)")

     

    Unhandled exception in thread started by <function check_errors.<locals>.wrapper
    
     at 0x031BD6F0>
    
    Traceback (most recent call last):
    
      File "C:Python36libsite-packagesdjangodbackendsasease.py", line 213
    
    , in ensure_connection
    
        self.connect()
    
      File "C:Python36libsite-packagesdjangodbackendsasease.py", line 189
    
    , in connect
    
        self.connection = self.get_new_connection(conn_params)
    
      File "C:Python36libsite-packagesdjangodbackendsmysqlase.py", line 27
    
    4, in get_new_connection
    
        conn = Database.connect(**conn_params)
    
      File "C:Python36libsite-packagesMySQLdb\__init__.py", line 86, in Connect
    
        return Connection(*args, **kwargs)
    
      File "C:Python36libsite-packagesMySQLdbconnections.py", line 204, in __in
    
    it__
    
        super(Connection, self).__init__(*args, **kwargs2)
    
    _mysql_exceptions.OperationalError: (1045, "Access denied for user ‘ODBC‘@‘local
    
    host‘ (using password: YES)")
    
     
    
    The above exception was the direct cause of the following exception:
    
     
    
    Traceback (most recent call last):
    
      File "C:Python36libsite-packagesdjangoutilsautoreload.py", line 227, in
    
    wrapper
    
        fn(*args, **kwargs)
    
      File "C:Python36libsite-packagesdjangocoremanagementcommands
    unserver.
    
    py", line 125, in inner_run
    
        self.check(display_num_errors=True)
    
      File "C:Python36libsite-packagesdjangocoremanagementase.py", line 359,
    
     in check
    
        include_deployment_checks=include_deployment_checks,
    
      File "C:Python36libsite-packagesdjangocoremanagementase.py", line 346,
    
     in _run_checks
    
        return checks.run_checks(**kwargs)
    
      File "C:Python36libsite-packagesdjangocorechecks
    egistry.py", line 81,
    
    in run_checks
    
        new_errors = check(app_configs=app_configs)
    
      File "C:Python36libsite-packagesdjangocorechecksmodel_checks.py", line
    
    30, in check_all_models
    
        errors.extend(model.check(**kwargs))
    
      File "C:Python36libsite-packagesdjangodbmodelsase.py", line 1282, in c
    
    heck
    
        errors.extend(cls._check_fields(**kwargs))
    
      File "C:Python36libsite-packagesdjangodbmodelsase.py", line 1357, in _
    
    check_fields
    
        errors.extend(field.check(**kwargs))
    
      File "C:Python36libsite-packagesdjangodbmodelsfields\__init__.py", line
    
     909, in check
    
        errors = super(AutoField, self).check(**kwargs)
    
      File "C:Python36libsite-packagesdjangodbmodelsfields\__init__.py", line
    
     219, in check
    
        errors.extend(self._check_backend_specific_checks(**kwargs))
    
      File "C:Python36libsite-packagesdjangodbmodelsfields\__init__.py", line
    
     322, in _check_backend_specific_checks
    
        return connections[db].validation.check_field(self, **kwargs)
    
      File "C:Python36libsite-packagesdjangodbackendsmysqlvalidation.py", l
    
    ine 49, in check_field
    
        field_type = field.db_type(self.connection)
    
      File "C:Python36libsite-packagesdjangodbmodelsfields\__init__.py", line
    
     640, in db_type
    
        return connection.data_types[self.get_internal_type()] % data
    
      File "C:Python36libsite-packagesdjangoutilsfunctional.py", line 35, in _
    
    _get__
    
        res = instance.__dict__[self.name] = self.func(instance)
    
      File "C:Python36libsite-packagesdjangodbackendsmysqlase.py", line 17
    
    4, in data_types
    
        if self.features.supports_microsecond_precision:
    
      File "C:Python36libsite-packagesdjangoutilsfunctional.py", line 35, in _
    
    _get__
    
        res = instance.__dict__[self.name] = self.func(instance)
    
      File "C:Python36libsite-packagesdjangodbackendsmysqlfeatures.py", lin
    
    e 53, in supports_microsecond_precision
    
        return self.connection.mysql_version >= (5, 6, 4) and Database.version_info
    
    >= (1, 2, 5)
    
      File "C:Python36libsite-packagesdjangoutilsfunctional.py", line 35, in _
    
    _get__
    
        res = instance.__dict__[self.name] = self.func(instance)
    
      File "C:Python36libsite-packagesdjangodbackendsmysqlase.py", line 38
    
    5, in mysql_version
    
        with self.temporary_connection() as cursor:
    
      File "C:Python36libcontextlib.py", line 82, in __enter__
    
        return next(self.gen)
    
      File "C:Python36libsite-packagesdjangodbackendsasease.py", line 591
    
    , in temporary_connection
    
        cursor = self.cursor()
    
      File "C:Python36libsite-packagesdjangodbackendsasease.py", line 254
    
    , in cursor
    
        return self._cursor()
    
      File "C:Python36libsite-packagesdjangodbackendsasease.py", line 229
    
    , in _cursor
    
        self.ensure_connection()
    
      File "C:Python36libsite-packagesdjangodbackendsasease.py", line 213
    
    , in ensure_connection
    
        self.connect()
    
      File "C:Python36libsite-packagesdjangodbutils.py", line 94, in __exit__
    
        six.reraise(dj_exc_type, dj_exc_value, traceback)
    
      File "C:Python36libsite-packagesdjangoutilssix.py", line 685, in reraise
    
     
    
        raise value.with_traceback(tb)
    
      File "C:Python36libsite-packagesdjangodbackendsasease.py", line 213
    
    , in ensure_connection
    
        self.connect()
    
      File "C:Python36libsite-packagesdjangodbackendsasease.py", line 189
    
    , in connect
    
        self.connection = self.get_new_connection(conn_params)
    
      File "C:Python36libsite-packagesdjangodbackendsmysqlase.py", line 27
    
    4, in get_new_connection
    
        conn = Database.connect(**conn_params)
    
      File "C:Python36libsite-packagesMySQLdb\__init__.py", line 86, in Connect
    
        return Connection(*args, **kwargs)
    
      File "C:Python36libsite-packagesMySQLdbconnections.py", line 204, in __in
    
    it__
    
        super(Connection, self).__init__(*args, **kwargs2)
    
    django.db.utils.OperationalError: (1045, "Access denied for user ‘ODBC‘@‘localho
    
    st‘ (using password: YES)")

    这里很奇怪为什么我配置的用户是 admin_py 怎么会显示 ‘ODBC’@‘localhost’?

    有人说是账号密码错误,通过报错看来的和账号密码错误相关,但是手工去登陆mysql是OK的啊!

    折腾了一会儿,仔细看官方文档配置:

    DATABASES = {
        ‘default‘: {
            ‘ENGINE‘: ‘django.db.backends.postgresql‘,
            ‘NAME‘: ‘mydatabase‘,
            ‘USER‘: ‘mydatabaseuser‘,
            ‘PASSWORD‘: ‘mypassword‘,
            ‘HOST‘: ‘127.0.0.1‘,
            ‘PORT‘: ‘5432‘,
        }}

    我自己的配置:

    DATABASES = {
        ‘default‘: {
            ‘ENGINE‘: ‘django.db.backends.mysql‘,
            ‘HOST‘: ‘127.0.0.1‘,
            ‘PORT‘: 3306,
            ‘NAME‘: ‘platform_admin_py‘,
            ‘USERNAME‘: ‘admin_py‘,
            ‘PASSWORD‘: ‘admin‘,
        }
    }

    发现了没有?用户名的的那个KEY不对! 我承认我这是从网上看别人的配置写的,偷懒了,这就是代价

    本文出自 “影子骑士” 博客:http://andylhz2009.blog.51cto.com/728703/1923552

  • 相关阅读:
    ArrayList 和 LinkList 的区别
    fork()相关的源码解析
    http协议状态码及其意义
    数据库的死锁相关知识
    JDBC事务的相关知识
    请求http页面的相关过程
    static 关键字的作用
    计算机网络网络层的IP地址划分及子码
    文件的相关操作.
    set集合和深浅拷贝
  • 原文地址:https://www.cnblogs.com/fwl8888/p/9356445.html
Copyright © 2011-2022 走看看