欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

淺談MySQL中授權(quán)(grant)和撤銷授權(quán)(revoke)用法詳解

 更新時間:2016年09月05日 09:28:50   投稿:jingxian  
下面小編就為大家?guī)硪黄獪\談MySQL中授權(quán)(grant)和撤銷授權(quán)(revoke)用法詳解。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧

MySQL 賦予用戶權(quán)限命令的簡單格式可概括為:

grant 權(quán)限 on 數(shù)據(jù)庫對象 to 用戶

一、grant 普通數(shù)據(jù)用戶,查詢、插入、更新、刪除 數(shù)據(jù)庫中所有表數(shù)據(jù)的權(quán)利

grant select on testdb.* to common_user@'%' 
grant insert on testdb.* to common_user@'%' 
grant update on testdb.* to common_user@'%' 
grant delete on testdb.* to common_user@'%' 

或者,用一條 MySQL 命令來替代:

grant select, insert, update, delete on testdb.* to common_user@'%' 

二、grant 數(shù)據(jù)庫開發(fā)人員,創(chuàng)建表、索引、視圖、存儲過程、函數(shù)等權(quán)限

grant 創(chuàng)建、修改、刪除 MySQL 數(shù)據(jù)表結(jié)構(gòu)權(quán)限。

 grant create on testdb.* to developer@'192.168.0.%'; 
 grant alter on testdb.* to developer@'192.168.0.%'; 
 grant drop  on testdb.* to developer@'192.168.0.%'; 

grant 操作 MySQL 外鍵權(quán)限:

grant references on testdb.* to developer@'192.168.0.%';

grant 操作 MySQL 臨時表權(quán)限:

 

grant create temporary tables on testdb.* to developer@'192.168.0.%';

grant 操作 MySQL 索引權(quán)限:

grant index on testdb.* to developer@'192.168.0.%';

grant 操作 MySQL 視圖、查看視圖源代碼權(quán)限:

 grant create view on testdb.* to developer@'192.168.0.%'; 
 grant show  view on testdb.* to developer@'192.168.0.%'; 

grant 操作 MySQL 存儲過程、函數(shù)權(quán)限:

grant create routine on testdb.* to developer@'192.168.0.%'; -- now, can show procedure status 
grant alter routine on testdb.* to developer@'192.168.0.%'; -- now, you can drop a procedure 
grant execute    on testdb.* to developer@'192.168.0.%'; 

三、grant 普通 DBA 管理某個 MySQL 數(shù)據(jù)庫的權(quán)限 

 

grant all privileges on testdb to dba@'localhost'

 其中,關(guān)鍵字 “privileges” 可以省略。

四、grant 高級 DBA 管理 MySQL 中所有數(shù)據(jù)庫的權(quán)限

grant all on *.* to dba@'localhost' 

五、MySQL grant 權(quán)限,分別可以作用在多個層次上

1. grant 作用在整個 MySQL 服務(wù)器上:

grant select on *.* to dba@localhost; -- dba 可以查詢 MySQL 中所有數(shù)據(jù)庫中的表。 
grant all  on *.* to dba@localhost; -- dba 可以管理 MySQL 中的所有數(shù)據(jù)庫 

2. grant 作用在單個數(shù)據(jù)庫上:

grant select on testdb.* to dba@localhost; -- dba 可以查詢 testdb 中的表。 

3. grant 作用在單個數(shù)據(jù)表上:

grant select, insert, update, delete on testdb.orders to dba@localhost;

這里在給一個用戶授權(quán)多張表時,可以多次執(zhí)行以上語句。例如:

 

grant select(user_id,username) on smp.users to mo_user@'%' identified by '123345'; 
grant select on smp.mo_sms to mo_user@'%' identified by '123345'; 

 4. grant 作用在表中的列上:

grant select(id, se, rank) on testdb.apache_log to dba@localhost; 

5. grant 作用在存儲過程、函數(shù)上:

grant execute on procedure testdb.pr_add to 'dba'@'localhost' 
grant execute on function testdb.fn_add to 'dba'@'localhost' 

六、查看 MySQL 用戶權(quán)限

查看當前用戶(自己)權(quán)限:

show grants; 

查看其他 MySQL 用戶權(quán)限:

 

show grants for dba@localhost; 

 七、撤銷已經(jīng)賦予給 MySQL 用戶權(quán)限的權(quán)限。

revoke 跟 grant 的語法差不多,只需要把關(guān)鍵字 “to” 換成 “from” 即可:

 grant all on *.* to  dba@localhost; 
revoke all on *.* from dba@localhost; 

 八、MySQL grant、revoke 用戶權(quán)限注意事項

1. grant, revoke 用戶權(quán)限后,該用戶只有重新連接 MySQL 數(shù)據(jù)庫,權(quán)限才能生效。

2. 如果想讓授權(quán)的用戶,也可以將這些權(quán)限 grant 給其他用戶,需要選項 “grant option“

grant select on testdb.* to dba@localhost with grant option; 

這個特性一般用不到。實際中,數(shù)據(jù)庫權(quán)限最好由 DBA 來統(tǒng)一管理。

補充:
mysql授權(quán)表共有5個表:user、db、host、tables_priv和columns_priv。

授權(quán)表的內(nèi)容有如下用途:

user表

user表列出可以連接服務(wù)器的用戶及其口令,并且它指定他們有哪種全局(超級用戶)權(quán)限。在user表啟用的任何權(quán)限均是全局權(quán)限,并適用于所有數(shù)據(jù)庫。例如,如果你啟用了DELETE權(quán)限,在這里列出的用戶可以從任何表中刪除記錄,所以在你這樣做之前要認真考慮。

db表
db表列出數(shù)據(jù)庫,而用戶有權(quán)限訪問它們。在這里指定的權(quán)限適用于一個數(shù)據(jù)庫中的所有表。

host表
host表與db表結(jié)合使用在一個較好層次上控制特定主機對數(shù)據(jù)庫的訪問權(quán)限,這可能比單獨使用db好些。這個表不受GRANT和REVOKE語句的影響,所以,你可能發(fā)覺你根本不是用它。

tables_priv表
tables_priv表指定表級權(quán)限,在這里指定的一個權(quán)限適用于一個表的所有列。

columns_priv表
columns_priv表指定列級權(quán)限。這里指定的權(quán)限適用于一個表的特定列。

以上這篇淺談MySQL中授權(quán)(grant)和撤銷授權(quán)(revoke)用法詳解就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • 從零開始學(xué)習(xí)SQL查詢語句執(zhí)行順序

    從零開始學(xué)習(xí)SQL查詢語句執(zhí)行順序

    sql語言中的查詢的執(zhí)行順序,以前不是很了解,最近查閱了相關(guān)資料,在sql語言中,第一個被處理的字句總是from字句,最后執(zhí)行的limit操作,現(xiàn)在小編來和大家一起學(xué)習(xí)一下
    2019-05-05
  • mysql如何設(shè)置不區(qū)分大小寫

    mysql如何設(shè)置不區(qū)分大小寫

    在本篇文章里小編給大家整理了關(guān)于mysql設(shè)置不區(qū)分大小寫的方法,需要的朋友們跟著學(xué)習(xí)下。
    2020-06-06
  • MySQL執(zhí)行SQL語句的流程詳解

    MySQL執(zhí)行SQL語句的流程詳解

    這篇文章主要介紹了MySQL執(zhí)行SQL語句的流程詳解,文章圍繞主題展開詳細的內(nèi)容介紹,具有一定的參考價值,需要的小伙伴可以參考一下
    2022-09-09
  • Mysql常用函數(shù)之Rank排名函數(shù)詳解

    Mysql常用函數(shù)之Rank排名函數(shù)詳解

    這篇文章主要介紹了Mysql常用函數(shù)之Rank排名函數(shù)詳解,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-01-01
  • MySQL防止delete命令刪除數(shù)據(jù)的兩種方法

    MySQL防止delete命令刪除數(shù)據(jù)的兩種方法

    在sql中刪除數(shù)據(jù)庫中記錄我們會使用到delete命令,這樣如果不小心給刪除了很難恢復(fù)了,下面我來總結(jié)一些刪除數(shù)據(jù)但是不在數(shù)據(jù)庫刪除的方法,有需要的朋友可以參考一下
    2013-08-08
  • mysql巡檢腳本(必看篇)

    mysql巡檢腳本(必看篇)

    下面小編就為大家?guī)硪黄猰ysql巡檢腳本(必看篇)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-03-03
  • IDEA連接不上MySQL端口號占用的解決

    IDEA連接不上MySQL端口號占用的解決

    這篇文章主要介紹了IDEA連接不上MySQL端口號占用的解決,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-11-11
  • MySQL常用表級操作總結(jié)

    MySQL常用表級操作總結(jié)

    這篇文章主要為大家詳細介紹了MySQL中常用的表級操作,文中的示例代碼簡潔易懂,對我們學(xué)習(xí)MySQL有一定的幫助,感興趣的小伙伴可以學(xué)習(xí)一下
    2023-08-08
  • mysql 設(shè)置自動創(chuàng)建時間及修改時間的方法示例

    mysql 設(shè)置自動創(chuàng)建時間及修改時間的方法示例

    這篇文章主要介紹了mysql 設(shè)置自動創(chuàng)建時間及修改時間的方法,結(jié)合實例形式分析了mysql針對創(chuàng)建時間及修改時間相關(guān)操作技巧,需要的朋友可以參考下
    2019-09-09
  • Mysql中幾種插入效率的實例對比

    Mysql中幾種插入效率的實例對比

    這篇文章通過實例跟大家介紹了Mysql中幾種插入方法的效率對比,這其中包括逐條插入、基于事務(wù)的批量插入、單條語句一次插入多組數(shù)據(jù)以及導(dǎo)入數(shù)據(jù)文件等四種方法的對比,文中通過實例代碼介紹很詳細,需要的朋友們下來來一起看看吧。
    2017-04-04

最新評論