适用于: SQL Server 
Azure 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)
加密层次结构