首先我们应该知道Mysql数据库中的口令存储必须用password()函数加密它。因为在user表中是以加密形式存储口令,而不是作为纯文本。如果你没有加密,直接在数据库中执行以下语句:
mysql>use mysql;
mysql>insert into user (host,user,password) values(%,用户名,密码);
mysql>flush privileges;
相信结果不会让你满意。因为服务器比较的是加密的值,所以服务器连接一定失败。
这里需要说明的是flush privileges;这条命令起到了重新加载授权表。你也可以在shell下直接用mysqladmin -u root reload或者mysqladmin -u root flush-privileges来实现重载授权表。
在Mysql环境下,你可以使用以下语句进行设置密码: 1 mysql>insert into user(host,user,password) values(%,用户名,password("密码"); 2 mysql>set password for 用户名 = password("密码")
以上两种方法都必须进行重载授权表。
3 当然你也可以在创建一个用户时直接设置密码,grant语句将为你自动加密口令。
如:mysql>grant all on *.* to 用户名@% identified by "密码";
另外你也可以在shell环境下用mysqladmin程序来设置密码。
如:root$mysqladmin -u root password "密码" |