django2.0链接MYSQL 8.0的root更改密码问题.。出现的(1045, (using password:NO))玩死我

2 篇文章 0 订阅
1 篇文章 0 订阅

非常感谢这篇文章救了弄了一个下午的我,https://blog.csdn.net/M_C_ing/article/details/80412165

环境是WIN10的64位,MYSQL8.0, Django2.0.3

错误1: django.db.utils.OperationalError: (1045, "Access denied for user 'root'@'localhost' (using password: NO)")

本人在django链接mysql时,出现以下问题

检查密码并尝试使用mysql -u root -p命令登录,没问题。但使用mysql -u root也出现这个错误。

原因是。MYSQL8.0对比之前的版本, 的加密方式变了,所以需要用旧的方式加密, 更改密码。

解决方法如下, 其中newpassword是自己设置的新密码

mysql -u root -p
use mysql;
ALTER USER 'root'@'localhost' IDENTIFIED WITH mysql_native_password BY 'newpassword';  
FLUSH PRIVILEGES;  

 

错误2:django.db.utils.OperationalError: (1045, "Access denied for user 'root'@'localhost' (using password: YES)")

这个错误是密码错误的问题。如忘记密码请更改密码。具体请自行百度,不搬运。

如果是django的,请检查账号密码是否匹配,比如我的是这样的。django链接MYSQL就需要改下面两项而已。检查一下就行

检查setting文件里的代码。也没有问题。


DATABASES = {
    'default': {
        'ENGINE': 'django.db.backends.mysql',
        'HOST': 'localhost',
        'POST': '3306',
        'NAME': 'guest',
        'USER': 'root',
        'PASSWORD': "123456",
        'OPTIONS':{'init_command': "SET sql_mode='STRICT_TRANS_TABLES'",},
        #'NAME': os.path.join(BASE_DIR, 'db.sqlite3'),
    }
}

__init__文件的代码

import pymysql
pymysql.install_as_MySQLdb()

错误3:如果你没有设置root密码

那么直接命令行执行mysql命令

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值