mysql的許可權表有哪些

2022-06-27 22:00:36

mysql的許可權表有:1、user表,用來記錄允許連線到伺服器的賬號資訊,該表裡啟用的所有許可權都是全域性級的,適用於所有資料庫;2、db表,儲存了使用者對某個資料庫的操作許可權;3、tables_priv表,用來對單個表進行許可權設定;4、columns_priv表,用來對單個資料列進行許可權設定;5、procs_priv表,用於對儲存過程和儲存函數進行許可權設定。

本教學操作環境:windows7系統、mysql8版本、Dell G3電腦。

在 MySQL 資料庫中,許可權表有user 表、db 表、tables_priv 表、columns_priv 表和 procs_priv 表。

user許可權表

user 表是 MySQL 中最重要的一個許可權表,用來記錄允許連線到伺服器的賬號資訊。需要注意的是,在 user 表裡啟用的所有許可權都是全域性級的,適用於所有資料庫。

user 表中的欄位大致可以分為 4 類,分別是使用者列、許可權列、安全列和資源控制列。

使用者列

使用者列儲存了使用者連線 MySQL 資料庫時需要輸入的資訊。需要注意的是 MySQL 5.7 版本不再使用 Password 來作為密碼的欄位,而改成了 authentication_string。

許可權列

許可權列的欄位決定了使用者的許可權,用來描述在全域性範圍內允許對資料和資料庫進行的操作。

許可權大致分為兩大類,分別是高階管理許可權和普通許可權:

  • 高階管理許可權主要對資料庫進行管理,例如關閉服務的許可權、超級許可權和載入使用者等;

  • 普通許可權主要運算元據庫,例如查詢許可權、修改許可權等。

user 表的許可權列包括 Select_priv、Insert_ priv 等以 priv 結尾的欄位,這些欄位值的資料型別為 ENUM,可取的值只有 Y 和 N:Y 表示該使用者有對應的許可權,N 表示該使用者沒有對應的許可權。從安全形度考慮,這些欄位的預設值都為 N。

如果要修改許可權,可以使用 GRANT 語句為使用者賦予一些許可權,也可以通過 UPDATE 語句更新 user 表的方式來設定許可權。

安全列

安全列主要用來判斷使用者是否能夠登入成功,user 表中的安全列如下表所示:

user 表的安全列
欄位名欄位型別是否為空預設值說明
ssl_typeenum('','ANY','X509','SPECIFIED')NO 支援ssl標準加密安全欄位
ssl_cipherblobNO 支援ssl標準加密安全欄位
x509_issuerblobNO 支援x509標準欄位
x509_subjectblobNO 支援x509標準欄位
pluginchar(64)NOmysql_native_password引入plugins以進行使用者連線時的密碼驗證,plugin建立外部/代理使用者
password_expiredenum('N','Y')NON密碼是否過期 (N 未過期,y 已過期)
password_last_changedtimestampYES 記錄密碼最近修改的時間
password_lifetimesmallint(5) unsignedYES 設定密碼的有效時間,單位為天數
account_lockedenum('N','Y')NON使用者是否被鎖定(Y 鎖定,N 未鎖定)

注意:即使 password_expired 為「Y」,使用者也可以使用密碼登入 MySQL,但是不允許做任何操作。

通常標準的發行版不支援 ssl,讀者可以使用 SHOW VARIABLES LIKE "have_openssl" 語句來檢視是否具有 ssl 功能。如果 have_openssl 的值為 DISABLED,那麼則不支援 ssl 加密功能。

資源控制列

資源控制列的欄位用來限制使用者使用的資源,user 表中的資源控制列如表 4 所示。

user 表的資源控制列
欄位名欄位型別是否為空預設值說明
max_questionsint(11) unsignedNO0規定每小時允許執行查詢的操作次數
max_updatesint(11) unsignedNO0規定每小時允許執行更新的操作次數
max_connectionsint(11) unsignedNO0規定每小時允許執行的連線操作次數
max_user_connectionsint(11) unsignedNO0規定允許同時建立的連線次數

以上欄位的預設值為 0,表示沒有限制。一個小時內使用者查詢或者連線數量超過資源控制限制,使用者將被鎖定,直到下一個小時才可以在此執行對應的操作。可以使用 GRANT 語句更新這些欄位的值。

db表

db 表比較常用,是 MySQL 資料庫中非常重要的許可權表,表中儲存了使用者對某個資料庫的操作許可權。表中的欄位大致可以分為兩類,分別是使用者列和許可權列。

使用者列

db 表使用者列有 3 個欄位,分別是 Host、User、Db,標識從某個主機連線某個使用者對某個資料庫的操作許可權,這 3 個欄位的組合構成了 db 表的主鍵。

db 表的使用者列如下表所示:

欄位名欄位型別是否為空預設值說明
Hostchar(60)NO主機名
Dbchar(64)NO資料庫名
Userchar(32)NO使用者名稱

許可權列

db 表中的許可權列和 user 表中的許可權列大致相同,只是user 表中的許可權是針對所有資料庫的,而 db 表中的許可權只針對指定的資料庫。如果希望使用者只對某個資料庫有操作許可權,可以先將 user 表中對應的許可權設定為 N,然後在 db 表中設定對應資料庫的操作許可權。

tables_priv表和columns_priv表

tables_priv 表用來對單個表進行許可權設定,columns_priv 表用來對單個資料列進行許可權設定。tables_priv 表結構如下表所示:

欄位名欄位型別是否為空預設值說明
Hostchar(60)NO主機
Dbchar(64)NO資料庫名
Userchar(32)NO使用者名稱
Table_namechar(64)NO表名
Grantorchar(93)NO修改該記錄的使用者
TimestamptimestampNOCURRENT_TIMESTAMP修改該記錄的時間
Table_privset('Select','Insert','Update','Delete','
Create','Drop','Grant','References',
'Index','Alter','Create View','Show view','Trigger')
NO表示對錶的操作許可權,包括 Select、Insert、Update、Delete、Create、Drop、Grant、References、Index 和 Alter 等
Column_privset('Select','Insert','Update','References')NO表示對錶中的列的操作許可權,包括 Select、Insert、Update 和 References

columns_priv 表結構如下表所示:

欄位名欄位型別是否為空預設值說明
Hostchar(60)NO主機
Dbchar(64)NO資料庫名
Userchar(32)NO使用者名稱
Table_namechar(64)NO表名
Column_namechar(64)NO資料列名稱,用來指定對哪些資料列具有操作許可權
TimestamptimestampNOCURRENT_TIMESTAMP修改該記錄的時間
Column_privset('Select','Insert','Update','References')NO表示對錶中的列的操作許可權,包括 Select、Insert、Update 和 References

procs_priv表

procs_priv 表可以對儲存過程和儲存函數進行許可權設定,procs_priv 的表結構如表所示:

欄位名欄位型別是否為空預設值說明
Hostchar(60)NO主機名
Dbchar(64)NO資料庫名
Userchar(32)NO使用者名稱
Routine_namechar(64)NO表示儲存過程或函數的名稱
Routine_typeenum('FUNCTION','PROCEDURE')NO表示儲存過程或函數的型別,Routine_type 欄位有兩個值,分別是 FUNCTION 和 PROCEDURE。FUNCTION 表示這是一個函數;PROCEDURE 表示這是一個
儲存過程。
Grantorchar(93)NO插入或修改該記錄的使用者
Proc_privset('Execute','Alter Routine','Grant')NO表示擁有的許可權,包括 Execute、Alter Routine、Grant 3種
TimestamptimestampNOCURRENT_TIMESTAMP表示記錄更新時間

【相關推薦:】

以上就是mysql的許可權表有哪些的詳細內容,更多請關注TW511.COM其它相關文章!