系统城装机大师 - 固镇县祥瑞电脑科技销售部宣传站!

当前位置:首页 > 数据库 > Mysql > 详细页面

MySQL查询用户权限的方法总结

时间:2020-03-05来源:电脑系统城作者:电脑系统城

介绍两种查看MySQL用户权限的两种方法

1、 使用MySQL grants命令


 
  1. mysql> show grants for username@localhost;
  2.  
  3. +---------------------------------------------------------------------+
  4.  
  5. | Grants for root@localhost |
  6.  
  7. +---------------------------------------------------------------------+
  8.  
  9. | GRANT ALL PRIVILEGES ON *.* TO 'root'@'localhost' WITH GRANT OPTION |
  10.  
  11. +---------------------------------------------------------------------+

需要注意的是:

● username和ip的组合需要是在mysql.user表中存在的,具体可以通过 select * from mysql.user 命令查看

● ip地址如果是通配符格式需要加引号,例如:show grants for root@'172.%';

2、 使用MySQL select命令


 
  1. mysql> select * from mysql.user where user='root' and host='localhost' \G;
  2. *************************** 1. row ***************************
  3. Host: localhost
  4. User: root
  5. Password: **********************
  6. Select_priv: Y
  7. Insert_priv: Y
  8. Update_priv: Y
  9. Delete_priv: Y
  10. Create_priv: Y
  11. Drop_priv: Y
  12. Reload_priv: Y
  13. Shutdown_priv: Y
  14. Process_priv: Y
  15. File_priv: Y
  16. Grant_priv: Y
  17. References_priv: Y
  18. Index_priv: Y
  19. Alter_priv: Y
  20. Show_db_priv: Y
  21. Super_priv: Y
  22. Create_tmp_table_priv: Y
  23. Lock_tables_priv: Y
  24. Execute_priv: Y
  25. Repl_slave_priv: Y
  26. Repl_client_priv: Y
  27. Create_view_priv: Y
  28. Show_view_priv: Y
  29. Create_routine_priv: Y
  30. Alter_routine_priv: Y
  31. Create_user_priv: Y
  32. Event_priv: Y
  33. Trigger_priv: Y
  34. Create_tablespace_priv: Y
  35. ssl_type:
  36. ssl_cipher:
  37. x509_issuer:
  38. x509_subject:
  39. max_questions: 0
  40. max_updates: 0
  41. max_connections: 0
  42. max_user_connections: 0
  43. plugin: mysql_native_password
  44. authentication_string:
  45. password_expired: N
  46. 1 row in set (0.01 sec)

 

知识点扩展:

我们来创建一个测试账号test,授予表层级的权限


 
  1. mysql> drop user test;
  2. Query OK, 0 rows affected (0.00 sec)
  3. mysql> flush privileges;
  4. Query OK, 0 rows affected (0.00 sec)
  5. mysql> grant all on MyDB.kkk to test@'%' identified by 'test';
  6. Query OK, 0 rows affected (0.01 sec)
  7. mysql>
  8. mysql> show grants for test;
  9. +-----------------------------------------------------------------------------------------------------+
  10. | Grants for test@% |
  11. +-----------------------------------------------------------------------------------------------------+
  12. | GRANT USAGE ON *.* TO 'test'@'%' IDENTIFIED BY PASSWORD '*94BDCEBE19083CE2A1F959FD02F964C7AF4CFC29' |
  13. | GRANT ALL PRIVILEGES ON `MyDB`.`kkk` TO 'test'@'%' |
  14. +-----------------------------------------------------------------------------------------------------+
  15. 2 rows in set (0.00 sec)
  16. mysql> select * from mysql.tables_priv\G;
  17. *************************** 1. row ***************************
  18. Host: %
  19. Db: MyDB
  20. User: test
  21. Table_name: kkk
  22. Grantor: root@localhost
  23. Timestamp: 0000-00-00 00:00:00
  24. Table_priv: Select,Insert,Update,Delete,Create,Drop,References,Index,Alter,Create View,Showview,Trigger
  25. Column_priv:
  26. 1 row in set (0.01 sec)
  27. ERROR:
  28. No query specified
  29. mysql> <br>

我们来创建一个测试账号test,授予列层级的权限


 
  1. mysql> drop user test;
  2. Query OK, 0 rows affected (0.00 sec)
  3. mysql> flush privileges;
  4. Query OK, 0 rows affected (0.00 sec)
  5. mysql> grant select (id, col1) on MyDB.TEST1 to test@'%' identified by 'test';
  6. Query OK, 0 rows affected (0.01 sec)
  7. mysql> flush privileges;
  8. Query OK, 0 rows affected (0.00 sec)
  9. mysql>
  10. mysql> select * from mysql.columns_priv;
  11. +------+------+------+------------+-------------+---------------------+-------------+
  12. | Host | Db | User | Table_name | Column_name | Timestamp | Column_priv |
  13. +------+------+------+------------+-------------+---------------------+-------------+
  14. | % | MyDB | test | TEST1 | id | 0000-00-00 00:00:00 | Select |
  15. | % | MyDB | test | TEST1 | col1 | 0000-00-00 00:00:00 | Select |
  16. +------+------+------+------------+-------------+---------------------+-------------+
  17. 2 rows in set (0.00 sec)
  18. mysql> show grants for test;
  19. +-----------------------------------------------------------------------------------------------------+
  20. | Grants for test@% |
  21. +-----------------------------------------------------------------------------------------------------+
  22. | GRANT USAGE ON *.* TO 'test'@'%' IDENTIFIED BY PASSWORD '*94BDCEBE19083CE2A1F959FD02F964C7AF4CFC29' |
  23. | GRANT SELECT (id, col1) ON `MyDB`.`TEST1` TO 'test'@'%' |
  24. +-----------------------------------------------------------------------------------------------------+
  25. 2 rows in set (0.00 sec)
  26. mysql> <br>

到此这篇关于MySQL查询用户权限的方法总结的文章就介绍到这了,更多相关两种MySQL查询用户权限的方法内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

分享到:

相关信息

  • MySQL的核心查询语句详解

    一、单表查询 1、排序 2、聚合函数 3、分组 4、limit 二、SQL约束 1、主键约束 2、非空约束 3、唯一约束 4、外键约束 5、默认值 三、多表查询 1、内连接 1)隐式内连接: 2)显式内连接: 2、外连接 1)左外连接 2)右外连接 四...

    2023-10-30

  • Mysql中如何删除表重复数据

    Mysql删除表重复数据 表里存在唯一主键 没有主键时删除重复数据 Mysql删除表中重复数据并保留一条 准备一张表 用的是mysql8 大家自行更改 创建表并添加四条相同的数据...

    2023-10-30

系统教程栏目

栏目热门教程

人气教程排行

站长推荐

热门系统下载