首页/应用软件/内容

MySQL ODBC 3.51 Driver设置时出现Access Denied的问题处理

应用软件2022-10-30 阅读()
SQL是Structured Query Language(结构化查询语言)的缩写。SQL是专为数据库而建立的操作命令集,是一种功能齐全的数据库语言。在使用它时,只需要发出“做什么”的命令,“怎么做”是不用使用者考虑的。SQL功能强大、简单易学、使用方便,已经成为了数据库操作的基础,并且现在几乎所有的数据库均支持SQL。

MySQL ODBC 3.51 Driver - Access Denied

同事反馈在应用服务器上配置MySQL ODBC 3.51 Drive时,测试连接MySQL数据库时报下面错误:

ERROR [HYT00] [MySQL][ODBC 3.51 Driver]Access denied for user: 'xxx@xxxx' (Using password: YES)


那么出现这个错误,其实分多种情况:

1:账号密码错误或账号不存在。

账号密码错误或不存在,就会报ERROR [HYT00] [MySQL][ODBC 3.51 Driver]Access denied for user: 'xxx@xxxx' (Using password: YES)这样错误。

2:账号密码存在特殊字符,例如特殊字符! @ # $ % ^ ?,那么也可能碰到这个错误。

创建一个测试账号test,密码包含一个特殊字符!

mysql> grant select on MyDB.* to test@'%' identified by 'Ac3435!6p';
 
Query OK, 0 rows affected (0.00 sec)
 
 
 
mysql> flush privileges;
 
Query OK, 0 rows affected (0.00 sec)

然后在一测试服务器上,配置MySQL ODBC时就会出现这个错误。如下截图所示,

clip_image001[6]

clip_image002[6]

搜索了一下,发现是MySQL ODBC 3.51不允许复杂密码,如下英文资料所示, 但是我下载安装MySQL ODBC 5.3测试发现, 这个版本是完全可以的。当然不清楚从那个版本开始,已经开始支持复杂密码了。这个很坑爹的特性确实让人很懵!

MySQL ODBC 3.51 No-Complex Password

Warning – You might have a serious headache with MySQL ODBC 3.51 if the password in your GRANT command contains special characters, such as ! @ # $ % ^ ?. MySQL ODBC 3.51 ODBC Driver does not support these special characters in the password box. The only error message you would receive is “Access denied” (using password: YES)

另外,如果网络不通、端口不通、或者MySQL服务没有启用,则会报Can't connect to MySQL server on 'xxxxxx'(10060)"这个错误。

clip_image003[6]

以上就是MySQL ODBC 3.51 Driver配置时出现Access Denied的问题解决的详细内容,更多请关注php中文网其它相关文章!


学习教程快速掌握从入门到精通的SQL知识。



……

相关阅读