MySQL修改root密码的多种方法+给远程登录赋权

一、MySQL修改root密码的多种方法
在 Navicat for MySQL 下面直接执行 SET PASSWORD FOR 'root'@'localhost' = PASSWORD('newpass'); 就可以

方法1: 用SET PASSWORD命令

  mysql -u root
格式:mysql> set password for 用户名@localhost = password('新密码');
例子:mysql> set password for root@localhost = password('1234');

方法2:用mysqladmin 只改的localhost

  格式:mysqladmin -u用户名 -p旧密码 password 新密码。p和旧密码没有空格 例如
  1、 如root无密码,给root加个密码123。首先在DOS下进入目录mysql\bin,然后键入以下命令
[root@BI-162 ~]# mysqladmin -u root password 123
  2、 如果root已经设置过密码,将root的密码改为234 p和旧密码没有空格
[root@BI-162 ~]# mysqladmin -u root -p123 password 1234

方法3: 用UPDATE直接编辑user表

  mysql -u root -p
  mysql> use mysql;
  mysql> UPDATE user SET password = PASSWORD('新密码') WHERE user = 'root';
  mysql> FLUSH PRIVILEGES;

或 分别设置本地和远程登录密码,密码可不同
mysql> update mysql.user set password=password('123') where user='root' and host='localhost';
mysql> update mysql.user set password=password('123') where user='root' and host='%';
update mysql.user set password=password('123') where user='root' and host='BI-162';
mysql> flush privileges;

方法4:在忘记root密码的时候,可以这样
KILL掉系统里的MySQL进程;
  mysqld_safe --skip-grant-tables&
  mysql -u root mysql
  mysql> UPDATE user SET password=PASSWORD('新密码') WHERE user='root';
  mysql> flush privileges;

方法4:在忘记root密码的时候,可以这样
以windows为例:

  1. 关闭正在运行的MySQL服务。
  2. 打开DOS窗口,转到mysql\bin目录。
  3. 输入mysqld --skip-grant-tables 回车。--skip-grant-tables 的意思是启动MySQL服务的时候跳过权限表认证。
  4. 再开一个DOS窗口(因为刚才那个DOS窗口已经不能动了),转到mysql\bin目录。
  5. 输入mysql回车,如果成功,将出现MySQL提示符 >。
  6. 连接权限数据库: use mysql; 。
  7. 改密码:update user set password=password('123') where user='root';(别忘了最后加分号) 。
  8. 刷新权限(必须步骤):flush privileges; 。
  9. 退出 quit。
  10. 注销系统,再进入,使用用户名root和刚才设置的新密码123登录。

二、给远程服务器赋权
允许用户在指定IP进行远程登陆,如果想不限制链接的IP则设置为“%”即可
grant all PRIVILEGES on bidb. to root@'%' identified by '123';
grant all PRIVILEGES on pacs.
to root@'%' identified by '123';
grant all PRIVILEGES on mysql. to root@'%' identified by '123';
grant all PRIVILEGES on test_db.
to root@'192.168.1.101' identified by '123456';
grant all on . to root@'%' identified by 'root' with grant option;

mysql -u root -p
mysql> use mysql;
mysql>select host, user, password from user;
额外说明,从这张user表中,我们可以构建这样的权限体系。相同的用户名,从不同的机器上登陆时使用不同的密码。

©著作权归作者所有:来自51CTO博客作者终而有始的原创作品,如需转载,请注明出处,否则将追究法律责任

我们一起来让这个世界有趣一点

赞赏

0人进行了赞赏支持

更多相关文章

  1. chrome查看网站字符集编码的方法(不需要安装charset)
  2. html基础:form表单
  3. Eclipse导入MyEclipse项目时,无法识别为web项目的解决方法
  4. DSaaS,一个创新的云密码服务
  5. Safari 浏览器中自动填充用户名和密码功能介绍
  6. Jenkins-2.283 破解密码
  7. Linux下查看进程线程数的方法
  8. Apple M1芯片软件安装异常的解决方法
  9. 图片上传

随机推荐

  1. Google Docs 更新,提供 Honeycomb 平板更
  2. 《疯狂Android讲义》
  3. Android学习系列(39)--Android主题和样式
  4. Android UI Action Bar之ActionBarSherlo
  5. 社区讨论:Android的架构设计
  6. Android(安卓)开发之集成百度地图的定位
  7. 原有Android项目集成RN入坑计(一)
  8. android网络编程――使用Android中的网络
  9. Android 如何进行js交互
  10. Android WebView介绍