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
    评论
MySQL操作参考文献: 1. "MySQL :: MySQL 8.0 Reference Manual :: 13.2.5.2 INSERT Statement," MySQL, accessed September 21, 2021, https://dev.mysql.com/doc/refman/8.0/en/insert.html. 2. "MySQL :: MySQL 8.0 Reference Manual :: 13.2.9 SELECT Statement," MySQL, accessed September 21, 2021, https://dev.mysql.com/doc/refman/8.0/en/select.html. 3. "MySQL :: MySQL 8.0 Reference Manual :: 13.2.10 UPDATE Statement," MySQL, accessed September 21, 2021, https://dev.mysql.com/doc/refman/8.0/en/update.html. Socket通信参考文献: 1. "Socket Programming in Python (Guide)," Real Python, accessed September 21, 2021, https://realpython.com/python-sockets/. 2. "Python Socket Programming Tutorial," Guru99, accessed September 21, 2021, https://www.guru99.com/python-socket-programming-tutorial.html. 3. "Python Network Programming - TCP/IP Socket Programming," Tutorialspoint, accessed September 21, 2021, https://www.tutorialspoint.com/python_network_programming/python_socket_programming.htm. Flask框架参考文献: 1. "Flask Documentation (2.1.x)," Flask, accessed September 21, 2021, https://flask.palletsprojects.com/en/2.1.x/. 2. "Flask Mega-Tutorial Part I: Hello, World!," Miguel Grinberg, accessed September 21, 2021, https://blog.miguelgrinberg.com/post/the-flask-mega-tutorial-part-i-hello-world. 3. "Flask Web Development with Python Tutorial - Full Course," FreeCodeCamp, accessed September 21, 2021, https://www.youtube.com/watch?v=MwZwr5Tvyxo. HTML参考文献: 1. "HTML5," W3C, accessed September 21, 2021, https://www.w3.org/TR/html5/. 2. "HTML Tutorial," W3Schools, accessed September 21, 2021, https://www.w3schools.com/html/. 3. "HTML Cheatsheet," OverAPI, accessed September 21, 2021, https://overapi.com/html-dom/. CSS参考文献: 1. "CSS," W3C, accessed September 21, 2021, https://www.w3.org/Style/CSS/. 2. "CSS Tutorial," W3Schools, accessed September 21, 2021, https://www.w3schools.com/css/. 3. "CSS Cheatsheet," OverAPI, accessed September 21, 2021, https://overapi.com/css/. JavaScript参考文献: 1. "ECMAScript® 2021 Language Specification," ECMA International, accessed September 21, 2021, https://tc39.es/ecma262/. 2. "JavaScript Tutorial," W3Schools, accessed September 21, 2021, https://www.w3schools.com/js/. 3. "JavaScript Cheatsheet," OverAPI, accessed September 21, 2021, https://overapi.com/javascript/.
评论 9
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值