avatar

MySQL中DCL相关语句的使用

序言

​ 我们现在默认使用的都是 root 用户,超级管理员,拥有全部的权限。但是,一个公司里面的数据库服务器上面 可能同时运行着很多个项目的数据库。所以,我们应该可以根据不同的项目建立不同的用户,分配不同的权限来管 理和维护数据库

管理用户

添加用户

语法:

1
CREATE USER '用户名'@'主机名' IDENTIFIED BY '密码';

演示

1
2
3
4
-- 创建帐号hyl,密码123456的用户,该用户只能在当前电脑登陆数据库
CREATE USER 'hyl'@'localhost' IDENTIFIED BY '123456';
-- 创建帐号hyl,密码123456的用户,该用户可以在任意电脑登陆数据库,%表示任意电脑
CREATE USER 'hyl'@'%' IDENTIFIED BY '123456';

删除用户

1
DROP USER '用户名'@'主机名';

修改用户密码

1
2
3
4
5
UPDATE USER SET PASSWORD = PASSWORD('新密码') WHERE USER = '用户名';
UPDATE USER SET PASSWORD = PASSWORD('abc') WHERE USER = 'lisi';

SET PASSWORD FOR '用户名'@'主机名' = PASSWORD('新密码');
SET PASSWORD FOR 'root'@'localhost' = PASSWORD('123');

mysql中忘记了root用户的密码

  1. cmd – > net stop mysql 停止mysql服务[需要管理员运行该cmd]

  2. 使用无验证方式启动mysql服务: mysqld –skip-grant-tables

  3. 打开新的cmd窗口,直接输入mysql命令,敲回车。就可以登录成功

  4. use mysql;

  5. update user set password = password(‘你的新密码’) where user = ‘root’;

  6. 关闭两个窗口

  7. 打开任务管理器,手动结束mysqld.exe 的进程

  8. 启动mysql服务

  9. 使用新密码登录。

  10. 查询用户:
    – 1. 切换到mysql数据库
    USE myql;
    – 2. 查询user表
    SELECT * FROM USER;

    • 通配符: % 表示可以在任意主机使用用户登录数据库

权限管理

查询权限:

1
2
SHOW GRANTS FOR '用户名'@'主机名';
SHOW GRANTS FOR 'lisi'@'%';

授予权限:

1
2
3
4
grant 权限列表 on 数据库名.表名 to '用户名'@'主机名';

-- 给张三用户授予所有权限,在任意数据库任意表上
GRANT ALL ON *.* TO 'zhangsan'@'localhost';

撤销权限:

1
2
revoke 权限列表 on 数据库名.表名 from '用户名'@'主机名';
REVOKE UPDATE ON db3.`account` FROM 'lisi'@'%';
文章作者: 微信:hao_yongliang
文章链接: https://haoyongliang.gitee.io/2019/07/08/mysql/MySQL%E4%B8%ADDCL%E7%9B%B8%E5%85%B3%E8%AF%AD%E5%8F%A5%E7%9A%84%E4%BD%BF%E7%94%A8/
版权声明: 本博客所有文章除特别声明外,均采用 CC BY-NC-SA 4.0 许可协议。转载请注明来自 郝永亮的主页
打赏
  • 微信
    微信
  • 支付寶
    支付寶

评论