Django使用mysql8.0作为数据库遇到的问题解决

4 篇文章 0 订阅
1 篇文章 0 订阅

mysql作为Django web项目的数据库,昨天晚上进行了mysql升级,升级到了8.0。数据都没啥问题但是等用Django连接数据库的时候出现报错:

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

这就很神奇了,setting.py文件中的数据库配置没有变过,mysql数据库手动也能登录,库news_db也在。怎么就会报password:no了呢。百撕不得骑姐~
赶紧上网查一下原因。看到mysql升级到8.0之后的新特性有一条是更新了密码的加密方式。如果要用原来的Django连接mysql8.0就得将mysql的加密方式转变为原来的方式。
解决方法如下:
登录到mysql,并执行如下两条命令

ALTER USER 'root'@'localhost' IDENTIFIED WITH mysql_native_password BY 'newpassword';  
FLUSH PRIVILEGES;

同时将setting.py中的password字段改成新设置的newpassword。

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值