
在 MySQL 中,只有 root 用户可以通过更新 MySQL 数据库来更改密码。使用 root 用户登录到 MySQL 服务器后,可以使用 SET 语句来修改普通用户密码。语法格式如下:
SET PASSWORD FOR 'username'@'hostname' = PASSWORD ('newpwd');
其中,username 参数是普通用户的用户名,hostname 参数是普通用户的主机名,newpwd 是要更改的新密码。
注意:新密码必须使用 PASSWORD() 函数来加密,如果不使用 PASSWORD() 加密,也会执行成功,但是用户会无法登录。
如果是普通用户修改密码,可省略 FOR 子句来更改自己的密码。语法格式如下:
SET PASSWORD = PASSWORD('newpwd');
示例 1
首先创建一个没有密码的 testuser 用户,SQL 语句和运行结果如下:
mysql> CREATE USER 'testuser'@'localhost';
Query OK, 0 rows affected (014 sec)
root 用户登录 MySQL 服务器后,再使用 SET 语句将 testuser 用户的密码修改为“newpwd”,SQL 语句和运行结果如下:
mysql> SET PASSWORD FOR 'testuser'@'localhost' = PASSWORD("newpwd");
Query OK, 0 rows affected, 1 warning (001 sec)
由运行结果可以看出,SET 语句执行成功,testuser 用户的密码被成功设置为“newpwd”。用SecureCRT 远程登录服务器,拥有 root 权限的用户却没办法登录,出现如下错误(图1所示),如何改成能直接让 root 登录呢?(建议不要改,因为 root 用户拥有最高权限,比较危险)解决方案:root一般是被禁止登陆的,它拥有最高权限,比较危险,平时都是先登陆普通用户后再切到 root 或者sudo 来工作,如果实在有需求要改成让root用户直接登录,可以用如下方法:[root@pangpang ~]# cat /etc/ssh/sshd_config |grep PermitRootLogin yes[root@pangpang ~]# vi /etc/ssh/sshd_config # 编辑此文档
找到PermitRootLogin 参数,并改为 PermitRootLogin yes 保存退出。然后重启ssh服务
[root@pangpang ~]# /etc/initd/sshd restart # 重启ssh服务
欢迎分享,转载请注明来源:内存溢出
微信扫一扫
支付宝扫一扫
评论列表(0条)