Centos下MySql用户管理
1.創建用戶
CREATE USER 'username'@'host' IDENTIFIED BY 'password';?
2.用戶授權
GRANT privileges ON databasename.tablename TO 'username'@'host';說明: privileges - 用戶的操作權限,如SELECT , INSERT , UPDATE 等(詳細列表見該文最后面).如果要授予所的權限則使用ALL.;databasename - 數據庫名,tablename-表名,如果要授予該用戶對所有數據庫和表的相應操作權限則可用*表示, 如*.*.
例子:
注意:用以上命令授權的用戶不能給其它用戶授權,如果想讓該用戶可以授權,用以下命令:
GRANT privileges ON databasename.tablename TO 'username'@'host' WITH GRANT OPTION;?
3.取消授權
REVOKE privilege ON databasename.tablename FROM 'username'@'host';說明: privilege, databasename, tablename - 同授權部分.
例子:
注意: 假如你在給用戶'pig'@'%'授權的時候是這樣的(或類似的):GRANT SELECT ON test.user TO 'pig'@'%', 則在使用REVOKE SELECT ON *.* FROM 'pig'@'%';命令并不能撤銷該用戶對test數據庫中user表的SELECT 操作.相反,如果授權使用的是GRANT SELECT ON *.* TO 'pig'@'%';則REVOKE SELECT ON test.user FROM 'pig'@'%';命令也不能撤銷該用戶對test數據庫中user表的Select 權限.
具體信息可以用命令?SHOW GRANTS FOR 'pig'@'%'; ?查看.
?
4.設置或修改密碼
SET PASSWORD FOR 'username'@'host' = PASSWORD('newpassword');如果是當前登陸用戶用?SET PASSWORD = PASSWORD("newpassword");
例子:
SET PASSWORD FOR 'pig'@'%' = PASSWORD("123456");如果忘記root密碼,操作如下:
1).linux切換到root用戶
2).修改MySql的登陸設置,編輯my.cnf文件
?[root@promote /]# vi /etc/my.cnf?
在[mysqld]字段下加入一句:?skip-grant-tables
保存退出。
3).重新啟動mysqld
?[root@promote /]# service mysqld restart?
4).之后可以免密碼進入MySql,然后use mysql
[root@promote /]# mysql Welcome to the MySQL monitor. Commands end with ; or \g. Your MySQL connection id is 3 Server version: 5.7.18 MySQL Community Server (GPL)Copyright (c) 2000, 2017, Oracle and/or its affiliates. All rights reserved.Oracle is a registered trademark of Oracle Corporation and/or its affiliates. Other names may be trademarks of their respective owners.Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.mysql> use mysql; Reading table information for completion of table and column names You can turn off this feature to get a quicker startup with -ADatabase changed5).修改root用戶密碼
mysql> update mysql.user set authentication_string=password('root') where User='root' and Host='localhost'; Query OK, 1 row affected, 1 warning (0.00 sec) Rows matched: 1 Changed: 1 Warnings: 16).退出MySql,編輯my.cnf,刪除skip-grant-tables一行
7).可用root用戶的新密碼登進MySql
?
5.刪除用戶
DROP USER 'username'@'host';?
?
?
附表:在MySql中的操作權限
?
| ?ALTER | Allows use of ALTER TABLE. |
| ALTER ROUTINE | Alters or drops stored routines. |
| CREATE | Allows use of CREATE TABLE. |
| CREATE ROUTINE | Creates stored routines. |
| CREATE TEMPORARY TABLE | Allows use of CREATE TEMPORARY TABLE. |
| CREATE USER | Allows use of CREATE USER, DROP USER, RENAME USER, and REVOKE ALL PRIVILEGES. |
| CREATE VIEW | Allows use of CREATE VIEW. |
| DELETE | Allows use of DELETE. |
| DROP | Allows use of DROP TABLE. |
| EXECUTE | Allows the user to run stored routines. |
| FILE | Allows use of SELECT... INTO OUTFILE and LOAD DATA INFILE. |
| INDEX | Allows use of CREATE INDEX and DROP INDEX. |
| INSERT | Allows use of INSERT. |
| LOCK TABLES | Allows use of LOCK TABLES on tables for which the user also has SELECT privileges. |
| PROCESS | Allows use of SHOW FULL PROCESSLIST. |
| RELOAD | Allows use of FLUSH. |
| REPLICATION | Allows the user to ask where slave or master |
| CLIENT | servers are. |
| REPLICATION SLAVE | Needed for replication slaves. |
| SELECT | Allows use of SELECT. |
| SHOW DATABASES | Allows use of SHOW DATABASES. |
| SHOW VIEW | Allows use of SHOW CREATE VIEW. |
| SHUTDOWN | Allows use of mysqladmin shutdown. |
| SUPER | Allows use of CHANGE MASTER, KILL, PURGE MASTER LOGS, and SET GLOBAL SQL statements. Allows mysqladmin debug command. Allows one extra connection to be made if maximum connections are reached. |
| UPDATE | Allows use of UPDATE. |
| USAGE | Allows connection without any specific privileges. |
?
posted on 2017-06-10 20:08 LuoJunC 閱讀(...) 評論(...) 編輯 收藏轉載于:https://www.cnblogs.com/luojunc/p/6979775.html
總結
以上是生活随笔為你收集整理的Centos下MySql用户管理的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 备忘录 | 当我每晚闲暇时我在干什么(2
- 下一篇: 树莓派设置NTP同步