Navicat 出现1044/1045错误的解决方法

产生错误的原因是mysql帐户连接到远程mysql服务器没有足够的权限。

mysql安装后默认仅允许"localhost"连接。因此多数服务器端的脚本程序很容易连接到本地服务器的本地数据库。客户端计算机被远程服务器阻止直到配置好用户权限。

如果您想从您的桌面访问远程mysql服务器,首先需要知道mysql系统工作的权限。

用户信息存储在名字为"mysql"数据库的user, db, host, tables_priv和 columns_priv表中。mysql服务器启动时读这些表的内容。

MySQL访问控制涉及两个阶段:

   1。服务器检查您的桌面(主机地址或IP地址)是允许连接。
   2。假设可以连接,服务器检查每个请求,看看你是否有足够的权限来执行它。例如,创建表的权限,删除表的权限或修改表的权限。


MySQL服务器在两个阶段访问控制使用MySQL数据库的User, Db,和Host 表。


如果您的远程服务器支持SSH连接,你的Navicat将能够通过SSH隧道与远程MySQL数据库连接,而不进行任何更改现有的MySQL的权限设置。该隧道的SSH的主要优点是它允许我们可以从后面连接到MySQL服务器被防火墙阻止的端口,


步骤

你可以在MySQL服务器的命令提示符下运行以下命令。请咨询您的数据库管理员,因为他们通常会具有设置权限的管理权。

GRANT ALL PRIVILEGES ON *.* TO 'YourUserName'@'%' IDENTIFIED BY "YourPassword";

或者

GRANT ALL PRIVILEGES ON *.* TO 'YourUserName'@'YourIP' IDENTIFIED BY "YourPassword";