權限:GRANT、DENY、REVOKE
適用於:Azure Synapse AnalyticsAnalytics Platform System (PDW)Microsoft Fabric 中的 SQL 分析端點Microsoft Fabric 中的倉儲
使用 GRANT 和 DENY 語句,將安全性實體的許可權(例如資料庫、數據表、檢視表等)授與或拒絕安全性主體的許可權(登入、資料庫用戶或資料庫角色)。 使用 REVOKE 來移除某個權限的授與或拒絕。
伺服器層級權限會套用至登入。 資料庫層級權限會套用至資料庫使用者和資料庫角色。
若要查看已授與或拒絕哪些權限,請查詢 sys.server_permissions 和 sys.database_permissions 檢視。 未以明確方式對安全性主體授與或拒絕的權限,可藉由擁有具權限之角色的成員資格來繼承。 固定資料庫角色的權限無法變更,且不會顯示在 sys.server_permissions 和 sys.database_permissions 檢視中。
GRANT 會明確授與一或多個權限。
DENY 會對主體明確拒絕一或多個權限。
REVOKE 會移除現有的 GRANT 或 DENY 權限。
語法
-- Azure Synapse Analytics and Parallel Data Warehouse and Microsoft Fabric
GRANT
<permission> [ ,...n ]
[ ON [ <class_type> :: ] securable ]
TO principal [ ,...n ]
[ WITH GRANT OPTION ]
[;]
DENY
<permission> [ ,...n ]
[ ON [ <class_type> :: ] securable ]
TO principal [ ,...n ]
[ CASCADE ]
[;]
REVOKE
<permission> [ ,...n ]
[ ON [ <class_type> :: ] securable ]
[ FROM | TO ] principal [ ,...n ]
[ CASCADE ]
[;]
<permission> ::=
{ see the tables below }
<class_type> ::=
{
LOGIN
| DATABASE
| OBJECT
| ROLE
| SCHEMA
| USER
}
引數
<permission>[ ,...n ]
一或多個要授與、拒絕或撤銷的權限。
ON [ <class_type> :: ] securableON 子句描述要作為授與、拒絕或撤銷權限時之執行對象的 securable 參數。
<class_type> 安全性實體的類別類型。 這可以是 LOGIN、DATABASE、OBJECT、SCHEMA、ROLE 或 USER。 您也可以將權限授與 SERVERclass_type,但針對這些權限不需指定 SERVER。 當權限包含 DATABASE 一字 (例如 ALTER ANY DATABASE) 時,不需指定 DATABASE。 未指定任何 class_type 且權限類型未限制為伺服器或資料庫類別時,會假設類別為 OBJECT。
securable
要作為授與、拒絕或撤銷權限時之執行對象的登入、資料庫、資料表、檢視、結構描述、程序、角色或使用者的名稱。 指定物件名稱時,可以使用 Transact-SQL 語法慣例中所述的三部分命名規則來指定。
TO principal [ , ...n ]
一或多個被授與、拒絕或撤銷權限的主體。 主體是登入、資料庫使用者或資料庫角色的名稱。
FROM principal [ , ...n ]
一或多個要撤銷權限的主體。 主體是登入、資料庫使用者或資料庫角色的名稱。
FROM 只能與 REVOKE 陳述式搭配使用。
TO 可以與 GRANTDENY或 REVOKE搭配使用。
WITH GRANT OPTION
指出也會提供被授與者授與指定權限給其他主體的能力。
CASCADE
表示對指定的主體及被主體授與權限的所有其他主體拒絕或撤銷權限。 當主體擁有含 GRANT OPTION 的權限時,這是必要引數。
GRANT OPTION FOR
表示將撤銷授與指定權限的能力。 當您使用 CASCADE 引數時,這是必要引數。
重要
如果主體擁有不含 GRANT 選項的指定權限,則會撤銷權限本身。
權限
若要授與權限,授與者必須具有含 WITH GRANT OPTION 的權限本身,或具有隱含所要授與之權限的更高權限。 物件擁有者可以授與他們所擁有之物件的權限。 具有安全性實體之 CONTROL 權限的主體可以授與該安全性實體的權限。 db_owner 和 db_securityadmin 固定資料庫角色的成員可以授與資料庫中的任何權限。
一般備註
對主體拒絕或撤銷權限並不會影響已通過授權且目前正在執行的要求。 若要立即限制存取,您必須取消作用中的要求,或終止目前的工作階段。
注意
大多數固定伺服器角色在此版本中都無法使用。 請改用使用者定義的資料庫角色。 您無法將登入新增至 sysadmin 固定伺服器角色。 授與 CONTROL SERVER 權限會近似於 sysadmin 固定伺服器角色中的成員資格。
有些陳述式需要多個權限。 例如,若要建立資料表,需要資料庫中的 CREATE TABLE 權限,以及該資料表之上層資料表的 ALTER SCHEMA 權限。
Analytics Platform System (PDW) 有時會執行預存程式,將使用者動作散發至計算節點。 因此,不能拒絕整個資料庫的執行權限。 (例如 DENY EXECUTE ON DATABASE::<name> TO <user>;
會失敗)。因應之道就是拒絕對使用者結構描述或特定物件 (程序) 的執行權限。
在 Microsoft Fabric 中,目前無法明確執行 CREATE USER。 執行 GRANT 或 DENY 時,系統會自動建立使用者。
在 Microsoft Fabric 中,無法管理伺服器層級的許可權。
隱含和明確權限
「明確權限」 是藉由 GRANT 或 DENY 陳述式來賦予主體的 GRANT 或 DENY 權限。
「隱含權限」 是主體 (登入、使用者或資料庫角色) 從另一個資料庫角色繼承的 GRANT 或 DENY 權限。
隱含權限也可以繼承自涵蓋權限或父權限。 例如,藉由擁有資料表之上層結構描述的 UPDATE 權限或資料表的 CONTROL 權限,即可繼承資料表的 UPDATE 權限。
擁有權鏈結
當多個資料庫物件依序存取彼此時,此順序即稱為「鏈結」。 雖然此類鏈結不會獨立存在,當 SQL Server 周遊鏈結中的連結時,SQL Server 評估要素物件權限的方式,與單獨存取物件時不同。 擁有權鏈結對於管理安全性有很重要的影響。 如需擁有權鏈結的詳細資訊,請參閱擁有權鏈結和教學課程:擁有權鏈結和內容切換。
權限清單
伺服器層級權限
您可以從登入授與、拒絕及撤銷伺服器層級權限。
適用於伺服器的權限
CONTROL SERVER
ADMINISTER BULK OPERATIONS
ALTER ANY CONNECTION
ALTER ANY DATABASE
CREATE ANY DATABASE
ALTER ANY EXTERNAL DATA SOURCE
ALTER ANY EXTERNAL FILE FORMAT
ALTER ANY LOGIN
ALTER SERVER STATE
CONNECT SQL
VIEW ANY DEFINITION
VIEW ANY DATABASE
VIEW SERVER STATE
適用於登入的權限
CONTROL ON LOGIN
ALTER ON LOGIN
IMPERSONATE ON LOGIN
VIEW DEFINITION
資料庫層級權限
您可以從資料庫使用者和使用者定義的資料庫角色,授與、拒絕及撤銷資料庫層級權限。
適用於所有資料庫類別的權限
CONTROL
ALTER
VIEW DEFINITION
適用於除了使用者以外所有資料庫類別的權限
- TAKE OWNERSHIP
僅適用於資料庫的權限
ALTER ANY DATABASE
ALTER ON DATABASE
ALTER ANY DATASPACE
ALTER ANY ROLE
ALTER ANY SCHEMA
ALTER ANY USER
BACKUP DATABASE
CONNECT ON DATABASE
CREATE PROCEDURE
CREATE ROLE
CREATE SCHEMA
CREATE TABLE
CREATE VIEW
SHOWPLAN
僅適用於使用者的權限
- IMPERSONATE
適用於資料庫、結構描述及物件的權限
ALTER
刪除
執行 CREATE 陳述式之前,請先執行
Insert
SELECT
UPDATE
REFERENCES
如需了解每一種權限的定義,請參閱權限 (資料庫引擎)。
預設權限
下列清單說明預設權限:
藉由使用 CREATE LOGIN 陳述式來建立登入時,新登入會收到 CONNECT SQL 權限。
所有登入都是 public 伺服器角色的成員,且無法從 public中移除。
藉由使用 CREATE USER 權限來建立資料庫使用者時,該資料庫使用者會收到資料庫中的 CONNECT 權限。
所有主體 (包括 public 角色) 預設都沒有任何明確或隱含的權限。
當登入或使用者成為資料庫或物件的擁有者時,登入或使用者一律會擁有該資料庫或物件的所有權限。 擁有權權限無法變更,且會作為隱含權限而不會顯示。 GRANT、DENY 及 REVOKE 陳述式對擁有者沒有任何作用。
sa 登入具有應用裝置的所有權限。 類似於擁有權權限,sa 權限無法變更,且會作為隱含權限而不會顯示。 GRANT、DENY 及 REVOKE 陳述式對 sa 登入沒有任何作用。 您無法將 sa 登入重新命名。
USE 陳述式不需要權限。 所有主體都可以在任何資料庫上執行 USE 陳述式。
範例:Azure Synapse Analytics 和 Analytics Platform System (PDW)
A. 將伺服器層級權限授與登入
下列兩個陳述式會將伺服器層級權限授與某個登入。
GRANT CONTROL SERVER TO [Ted];
GRANT ALTER ANY DATABASE TO Mary;
B. 將伺服器層級權限授與登入
下列範例會將某個登入的伺服器層級權限授與某個伺服器主體 (另一個登入)。
GRANT VIEW DEFINITION ON LOGIN::Ted TO Mary;
C. 將資料庫層級權限授與使用者
下列範例會將某個使用者的資料庫層級權限授與某個資料庫主體 (另一個使用者)。
GRANT VIEW DEFINITION ON USER::[Ted] TO Mary;
D. 授與、拒絕及撤銷結構描述權限
下列 GRANT 陳述式會讓 Yuen 能夠從 dbo 結構描述中的任何資料表或檢視中選取資料。
GRANT SELECT ON SCHEMA::dbo TO [Yuen];
下列 DENY 陳述式會讓 Yuen 無法從 dbo 結構描述中的任何資料表或檢視中選取資料。 Yuen 即使藉由某個其他方式取得權限 (例如透過角色成員資格),也無法讀取資料。
DENY SELECT ON SCHEMA::dbo TO [Yuen];
下列 REVOKE 陳述式會移除 DENY 權限。 現在 Yuen 的明確權限已變成中性。 Yuen 或許能夠透過某個其他隱含權限 (例如角色成員資格) 從任何資料表中選取資料。
REVOKE SELECT ON SCHEMA::dbo TO [Yuen];
E. 示範選擇性 OBJECT:: 子句
由於 OBJECT 是權限陳述式的預設類別,因此下列兩個陳述式相同。 OBJECT:: 子句是選擇性的。
GRANT UPDATE ON OBJECT::dbo.StatusTable TO [Ted];
GRANT UPDATE ON dbo.StatusTable TO [Ted];