1.建立用戶mysql
CREATE USER 'username'@'host' IDENTIFIED BY 'password';
2.用戶受權linux
GRANT privileges ON databasename.tablename TO 'username'@'host';
說明: privileges - 用戶的操做權限,如SELECT , INSERT , UPDATE 等(詳細列表見該文最後面).若是要授予所的權限則使用ALL.;databasename - 數據庫名,tablename-表名,若是要授予該用戶對全部數據庫和表的相應操做權限則可用*表示, 如*.*.
例子: sql
GRANT SELECT, INSERT ON test.user TO 'pig'@'%'; GRANT ALL ON *.* TO 'pig'@'%';
注意:用以上命令受權的用戶不能給其它用戶受權,若是想讓該用戶能夠受權,用如下命令: 數據庫
GRANT privileges ON databasename.tablename TO 'username'@'host' WITH GRANT OPTION;
3.取消受權ide
REVOKE privilege ON databasename.tablename FROM 'username'@'host';
說明: privilege, databasename, tablename - 同受權部分.
例子: ui
REVOKE SELECT ON *.* FROM 'pig'@'%';
注意: 假如你在給用戶'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'@'%'; 查看.this
4.設置或修改密碼spa
SET PASSWORD FOR 'username'@'host' = PASSWORD('newpassword');
若是是當前登錄用戶用 SET PASSWORD = PASSWORD("newpassword");debug
例子: rest
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 -A Database changed
5).修改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: 1
6).退出MySql,編輯my.cnf,刪除skip-grant-tables一行
7).可用root用戶的新密碼登進MySql
5.刪除用戶
DROP USER 'username'@'host';
附表:在MySql中的操做權限