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, ) (Background on this error at: http://sqlalche.me/e/e3q8)

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

pip install pymysql

安装结束的URL:

mysql+pymysql://:@/[?]
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的,所以这里完全没有必要自己下载啊……

最后最后: 安装时候看到了这么一面
Python Flask 连接不上mysql 8.0数据库(错误为2059,1045,1049)_第1张图片
我原来第一次安装都是默认,默认是第一个选项,但是我这次读了读,不知为何感觉这里可能有问题,然后我很机智的选择了第2个

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

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

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

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

你可能感兴趣的:(python)