Python Flask 连接不上mysql 8.0数据库(错误为2059,1045,1049)

前提:

最近再上牛客网上的初级项目,然后里面数据要连接mysql 数据库,我一直用sqlite代替,用mysql就是连不上!!!

课程代码:

SQLALCHEMY_DATABASE_URI = 'mysql://root:123456@localhost/test'

我的结果:

sqlalchemy.exc.OperationalError: (_mysql_exceptions.OperationalError) (2059, <NULL>) (Background on this error at: http://sqlalche.me/e/e3q8)

这个是根本没有检测到数据库啊
百度百度:知乎答案
解决方案:

pip install pymysql

安装结束的URL:

mysql+pymysql://<username>:<password>@<host>/<dbname>[?<options>]
SQLALCHEMY_DATABASE_URI = 'mysql+pymysql://root:19871224@localhost:3306/test'

然后换了一个错误!!!

sqlalchemy.exc.OperationalError: (pymysql.err.OperationalError) (1045, "Access denied for user 'root'@'localhost' (using password: NO)") 

emmm,数据库密码的问题……
百度百度: 我试了试改root的密码,然后网上的改密码的句子我复制过去竟然说我语法错误!

update mysql.user set password=PASSword('123456') where user='root';

百度百度: 我mysql版本太新,user表没有password这个字段了,要把它换成authentitation_string(可能拼错了,可以自己在user表下列一下列名)

update mysql.user set authentication_string='123456' where user='root';

然后我终于换密码成功啦!!!然而,1045那个问题还是没有解决!!!!更加可怕的是,我的mysql数据库挂了!!!哈哈哈哈,数据库挂了!!!连接不上数据库啦。。。。然后又百度百度然后失败啦,哈哈哈哈哈哈,要死啊!!!!

mysql数据库卸载…参考网站

mysql数据库安装…
我发现安装过程中它提示了一个和python的一个connector没有检测到,我又很傻的自己去官网下……但是其实用之前pymysql就是用来连接python和mysql的,所以这里完全没有必要自己下载啊……

最后最后: 安装时候看到了这么一面
这里写图片描述
我原来第一次安装都是默认,默认是第一个选项,但是我这次读了读,不知为何感觉这里可能有问题,然后我很机智的选择了第2个

安装完成,我忍不住立刻来验证了一发:哈哈哈哈哈,终于不是1045了!!!!

(pymysql.err.InternalError) (1049, "Unknown database 'test'") 

哇,这个问题好解决啦,只要在数据库里创建一个test的数据库就可以啦。
然后运行时还有一些编码问题,不过可以运行,不影响数据库数据,至此,我的flask终于可以连接上mysql啦。

最后,看那个问题是密码的问题,新版的密码是自动用了sha256编码的。所以可以试试看不卸载,而是把那个密码字段改成原密码经过sha256加密过的密码(这里可以随便百度一下sha256加密,然后进去在线加密一下复制一下就好)填到密码字段试试。这个失败了再考虑重新安装数据库把加密方式换成以前的!!!

  • 2
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 9
    评论
评论 9
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值