DENY 程序集权限 (Transact-SQL)

适用于: SQL Server Azure SQL 托管实例

拒绝对程序集的权限。

Transact-SQL 语法约定

语法

  
DENY { permission [ ,...n ] } ON ASSEMBLY :: assembly_name  
    TO database_principal [ ,...n ]   
        [ CASCADE ]  
        [ AS denying_principal ]  

参数

permission
指定可拒绝授予程序集的权限。 如下所列。

ON ASSEMBLY ::assembly_name
指定拒绝将其权限授予他人的程序集。 需要使用作用域限定符“::”。

database_principal
指定要对其拒绝权限的主体。 下列类型作之一:

  • 数据库用户

  • 数据库角色

  • 应用程序角色

  • 映射到 Windows 登录名的数据库用户

  • 映射到 Windows 组的数据库用户

  • 映射到证书的数据库用户

  • 映射到非对称密钥的数据库用户

  • 未映射到服务器主体的数据库用户。

CASCADE
指示要拒绝的权限也会被对此主体授予该权限的其他主体拒绝。

denying_principal
指定一个主体,执行该查询的主体从该主体获得拒绝授予该权限的权利。 下列类型作之一:

  • 数据库用户

  • 数据库角色

  • 应用程序角色

  • 映射到 Windows 登录名的数据库用户

  • 映射到 Windows 组的数据库用户

  • 映射到证书的数据库用户

  • 映射到非对称密钥的数据库用户

  • 未映射到服务器主体的数据库用户。

备注

程序集是一个数据库级的安全对象,包含于权限层次结构中作为其父级的数据库中。 下面列出了可拒绝授予程序集的最特定和最受限的权限,以及隐含这些权限的更常用权限。

程序集权限 程序集权限隐含的权限 数据库权限隐含的权限
CONTROL CONTROL CONTROL
TAKE OWNERSHIP CONTROL CONTROL
ALTER CONTROL ALTER ANY ASSEMBLY
REFERENCES CONTROL REFERENCES
VIEW DEFINITION CONTROL VIEW DEFINITION

权限

需要对程序集具有 CONTROL 权限。 如果使用 AS 选项,则指定的主体必须拥有程序集。

另请参阅

DENY (Transact-SQL)
权限(数据库引擎)
主体(数据库引擎)
CREATE CERTIFICATE (Transact-SQL)
CREATE ASYMMETRIC KEY (Transact-SQL)
CREATE APPLICATION ROLE (Transact-SQL)
CREATE ASSEMBLY (Transact-SQL)
加密层次结构