Python框架之Django的数据库配置问题

准备开始python的环境,用django框架其默认的数据库是sqlite3 ,要改用mysql来存储数据

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


Unhandled exception in thread started by <function check_errors.<locals>.wrapper

at 0x031BD6F0>

Traceback (most recent call last):

File "C:\Python36\lib\site-packages\django\db\backends\base\base.py", line 213

, in ensure_connection

self.connect()

File "C:\Python36\lib\site-packages\django\db\backends\base\base.py", line 189

, in connect

self.connection = self.get_new_connection(conn_params)

File "C:\Python36\lib\site-packages\django\db\backends\mysql\base.py", line 27

4, in get_new_connection

conn = Database.connect(**conn_params)

File "C:\Python36\lib\site-packages\MySQLdb\__init__.py", line 86, in Connect

return Connection(*args, **kwargs)

File "C:\Python36\lib\site-packages\MySQLdb\connections.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:\Python36\lib\site-packages\django\utils\autoreload.py", line 227, in

wrapper

fn(*args, **kwargs)

File "C:\Python36\lib\site-packages\django\core\management\commands\runserver.

py", line 125, in inner_run

self.check(display_num_errors=True)

File "C:\Python36\lib\site-packages\django\core\management\base.py", line 359,

in check

include_deployment_checks=include_deployment_checks,

File "C:\Python36\lib\site-packages\django\core\management\base.py", line 346,

in _run_checks

return checks.run_checks(**kwargs)

File "C:\Python36\lib\site-packages\django\core\checks\registry.py", line 81,

in run_checks

new_errors = check(app_configs=app_configs)

File "C:\Python36\lib\site-packages\django\core\checks\model_checks.py", line

30, in check_all_models

errors.extend(model.check(**kwargs))

File "C:\Python36\lib\site-packages\django\db\models\base.py", line 1282, in c

heck

errors.extend(cls._check_fields(**kwargs))

File "C:\Python36\lib\site-packages\django\db\models\base.py", line 1357, in _

check_fields

errors.extend(field.check(**kwargs))

File "C:\Python36\lib\site-packages\django\db\models\fields\__init__.py", line

909, in check

errors = super(AutoField, self).check(**kwargs)

File "C:\Python36\lib\site-packages\django\db\models\fields\__init__.py", line

219, in check

errors.extend(self._check_backend_specific_checks(**kwargs))

File "C:\Python36\lib\site-packages\django\db\models\fields\__init__.py", line

322, in _check_backend_specific_checks

return connections[db].validation.check_field(self, **kwargs)

File "C:\Python36\lib\site-packages\django\db\backends\mysql\validation.py", l

ine 49, in check_field

field_type = field.db_type(self.connection)

File "C:\Python36\lib\site-packages\django\db\models\fields\__init__.py", line

640, in db_type

return connection.data_types[self.get_internal_type()] % data

File "C:\Python36\lib\site-packages\django\utils\functional.py", line 35, in _

_get__

res = instance.__dict__[self.name] = self.func(instance)

File "C:\Python36\lib\site-packages\django\db\backends\mysql\base.py", line 17

4, in data_types

if self.features.supports_microsecond_precision:

File "C:\Python36\lib\site-packages\django\utils\functional.py", line 35, in _

_get__

res = instance.__dict__[self.name] = self.func(instance)

File "C:\Python36\lib\site-packages\django\db\backends\mysql\features.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:\Python36\lib\site-packages\django\utils\functional.py", line 35, in _

_get__

res = instance.__dict__[self.name] = self.func(instance)

File "C:\Python36\lib\site-packages\django\db\backends\mysql\base.py", line 38

5, in mysql_version

with self.temporary_connection() as cursor:

File "C:\Python36\lib\contextlib.py", line 82, in __enter__

return next(self.gen)

File "C:\Python36\lib\site-packages\django\db\backends\base\base.py", line 591

, in temporary_connection

cursor = self.cursor()

File "C:\Python36\lib\site-packages\django\db\backends\base\base.py", line 254

, in cursor

return self._cursor()

File "C:\Python36\lib\site-packages\django\db\backends\base\base.py", line 229

, in _cursor

self.ensure_connection()

File "C:\Python36\lib\site-packages\django\db\backends\base\base.py", line 213

, in ensure_connection

self.connect()

File "C:\Python36\lib\site-packages\django\db\utils.py", line 94, in __exit__

six.reraise(dj_exc_type, dj_exc_value, traceback)

File "C:\Python36\lib\site-packages\django\utils\six.py", line 685, in reraise

raise value.with_traceback(tb)

File "C:\Python36\lib\site-packages\django\db\backends\base\base.py", line 213

, in ensure_connection

self.connect()

File "C:\Python36\lib\site-packages\django\db\backends\base\base.py", line 189

, in connect

self.connection = self.get_new_connection(conn_params)

File "C:\Python36\lib\site-packages\django\db\backends\mysql\base.py", line 27

4, in get_new_connection

conn = Database.connect(**conn_params)

File "C:\Python36\lib\site-packages\MySQLdb\__init__.py", line 86, in Connect

return Connection(*args, **kwargs)

File "C:\Python36\lib\site-packages\MySQLdb\connections.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不对! 我承认我这是从网上看别人的配置写的,偷懒了,这就是代价

时间: 2024-07-29 10:17:38

Python框架之Django的数据库配置问题的相关文章

Python框架之Django的相册组件

Python框架之Django的相册组件 恩,没错,又是Django,虽然学习笔记已经结贴,但是学习笔记里都是基础的,Django的东西不管怎么说还是很多的,要学习的东西自然不会仅仅用十几篇博文就能学习的完的.好了,废话不多说,今天介绍的是Django的一个开源的组件photologue,组件被作者放在了Github上,想看源码的点击这里. 准备工作 下载组件.下载地址在这里: http://code.google.com/p/django-photologue/ 解压缩后,进入目录下执行命令行

Python框架之Django学习笔记(九)

模型 之前,我们用 Django 建造网站的基本途径: 建立视图和 URLConf . 正如我们所阐述的,视图负责处理一些主观逻辑,然后返回响应结果. 作为例子之一,我们的主观逻辑是要计算当前的日期和时间. 在当代 Web 开发中,主观逻辑经常牵涉到与数据库的交互. 数据库驱动网站在后台连接数据库服务器,从中取出一些数据,然后在 Web 页面用漂亮的格式展示这些数据. 这个网站也可能会向访问者提供修改数据库数据的方法. 许多复杂的网站都提供了以上两个功能的某种结合. 例如 Amazon.com

Python框架之Django学习笔记(十)

又是一周周末,如约学习Django框架.在上一次,介绍了MVC开发模式以及Django自己的MVT开发模式,此次,就从数据处理层Model谈起. 数据库配置 首先,我们需要做些初始配置:我们需要告诉Django使用什么数据库以及如何连接数据库.假定你已经完成了数据库服务器的安装和激活,并且已经在其中创建了数据库(例如,用 CREATE DATABASE语句). 如果你使用SQLite,不需要这步安装,因为SQLite使用文件系统上的独立文件来存储数据.和前面章节提到的 TEMPLATE_DIRS

Python框架之Django学习笔记(十一)

话说上次说到数据库的基本访问,而数据库我们主要进行的操作就是CRUD,也即是做计算处理时的增加(Create).读取(Retrieve)(重新得到数据).更新(Update)和删除(Delete),俗称:增删改查.废话不多说,学习开始. 插入和更新数据 你已经知道怎么做了: 先使用一些关键参数创建对象实例,如下: 1 >>> p = Publisher(name='Apress', 2 ... address='2855 Telegraph Ave.', 3 ... city='Berk

Python框架之Django学习笔记(十二)

Django站点管理 十一转眼结束,说好的充电没能顺利开展,反而悠闲的看了电视剧以及去影院看了新上映的<心花路放>.<亲爱的>以及<黄金时代>,说好的劳逸结合现在回首看去,如果睡觉吃饭算是的话,那倒是挺多.是啊,十一过去了,也该收收心,开始准备过年了.啊,不对,准备工作.扯淡到此结束,接下来,开始学习Django的站点管理. 管理界面有一问题: 创建它太繁琐. 当你开发对公众的功能时,网页开发是有趣的,但是创建管理界面通常是千篇一律的. 你必须认证用户,显示并管理表格,

Python框架之Django学习笔记(一)

Django历史: Django 是从真实世界的应用中成长起来的,它是由 堪萨斯(Kansas)州 Lawrence 城中的一个 网络开发小组编写的. 它诞生于 2003 年秋天,那时 Lawrence Journal-World 报纸的 程序员 Adrian Holovaty 和 Simon Willison 开始用 Python 来编写程序. 当时他们的 World Online 小组制作并维护当地的几个新闻站点, 并在以新闻界特有的快节奏开发环境中逐渐发展. 这些站点包括有 LJWorld

Python框架之Django学习笔记(六)

模板 上篇博文学习了动态视图,但是,视图中返回文本的方式有点特别. 也就是说,HTML被直接硬编码在 Python 代码之中. 1 def current_datetime(request): 2 now = datetime.datetime.now() 3 html = "<html><body>It is now %s.</body></html>" % now 4 return HttpResponse(html) 尽管这种技术便

Python框架之Django学习笔记(十七)

Django框架之表单(续二) PS:本博客欢迎转发,但请注明博客地址及作者~ 博客地址:http://www.cnblogs.com/voidy/ <.)#)))≦ 今天的这篇博客将是Django学习笔记博客的最后一篇,基本每周最少一篇的Django框架学习,坚持到今天也实属不易,当然了,这个框架的学习仅仅是Django框架的基础部分了,不过也够我们平时搭个简易的网站或者个人博客什么的.希望通过这一系列的博文,让大家也从中体会到Django框架的魅力所在,如果很不幸,你没有体会到,只能说明我水

Python框架之Django学习笔记(十五)

表单 从Google的简朴的单个搜索框,到常见的Blog评论提交表单,再到复杂的自定义数据输入接口,HTML表单一直是交互性网站的支柱.本次内容将介绍如何用Django对用户通过表单提交的数据进行访问.有效性检查以及其它处理. 与此同时,我们将介绍HttpRequest对象和Form对象. 从Request对象中获取数据 在前面讲述View的函数时已经介绍过HttpRequest对象了,但当时并没有讲太多. 让我们回忆下:每个view函数的第一个参数是一个HttpRequest对象,就像下面这个