最近再上牛客网上的初级项目,然后里面数据要连接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的,所以这里完全没有必要自己下载啊……
最后最后: 安装时候看到了这么一面
我原来第一次安装都是默认,默认是第一个选项,但是我这次读了读,不知为何感觉这里可能有问题,然后我很机智的选择了第2个
安装完成,我忍不住立刻来验证了一发:哈哈哈哈哈,终于不是1045了!!!!
(pymysql.err.InternalError) (1049, "Unknown database 'test'")
哇,这个问题好解决啦,只要在数据库里创建一个test的数据库就可以啦。
然后运行时还有一些编码问题,不过可以运行,不影响数据库数据,至此,我的flask终于可以连接上mysql啦。