mysql 411协议_错误:客户端不支持服务器请求的身份验证协议;考虑升级MySQL客户端-问答-阿里云开发者社区-阿里云...

在执行JDBC程序时遇到MySQL 411协议错误,提示客户端不支持服务器请求的身份验证协议。尝试通过升级MySQL客户端、更改用户权限和更新用户密码等方式解决,但过程中遇到SQL语法错误。需要检查MySQL服务器版本并参照手册修正SQL语句。
摘要由CSDN通过智能技术生成

执行JDBC程序时,连接到数据库时出现以下错误:

Exception in thread "main" com.mysql.jdbc.exceptions.MySQLNonTransientConnectionException: Client does not support authentication protocol requested by server; consider upgrading MySQL client at com.mysql.jdbc.SQLError.createSQLException(SQLError.java:921) at com.mysql.jdbc.MysqlIO.checkErrorPacket(MysqlIO.java:2985) at com.mysql.jdbc.MysqlIO.checkErrorPacket(MysqlIO.java:885) at com.mysql.jdbc.MysqlIO.secureAuth411(MysqlIO.java:3421) at com.mysql.jdbc.MysqlIO.doHandshake(MysqlIO.java:1247) at com.mysql.jdbc.Connection.createNewIO(Connection.java:2775) at com.mysql.jdbc.Connection.

(Connection.java:1555) at com.mysql.jdbc.NonRegisteringDriver.connect(NonRegisteringDriver.java:285) at java.sql.DriverManager.getConnection(DriverManager.java:664) at java.sql.DriverManager.getConnection(DriverManager.java:270) at main.java.MyFirstJdbcProgram.readDataBase(MyFirstJdbcProgram.java:23) at main.java.Main.main(Main.java:6) 在研究此问题时,我知道以下错误是因为我需要向用户授予特权,所以请按照以下步骤操作

mysql -u root -p 然后输入密码 然后我跑了

GRANT ALL PRIVILEGES ON . TO 'root'@'localhost' IDENTIFIED BY 'mypassword';

我也用过

UPDATE user SET authentication_string=password('mypassword') WHERE user='root'; 但是我正在错误以下

错误1064(42000):您的SQL语法有错误;检查与您的MySQL服务器版本相对应的手册以获取正确的语法,以在第1行的'IDENTIFIED BY'mypassword'附近使用

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值