DENY 证书权限 (Transact-SQL)

适用于:SQL Server Azure SQL 数据库 Azure SQL 托管实例 Microsoft Fabric SQL 数据库

拒绝对证书的权限。

Transact-SQL 语法约定

语法

  
DENY permission  [ ,...n ]   
    ON CERTIFICATE :: certificate_name   
    TO principal [ ,...n ]  
    [ CASCADE ]  
    [ AS denying_principal ]  

参数

permission
指定可拒绝授予证书的权限。 如下所列。

ON CERTIFICATE ::certificate_name
指定拒绝将其权限授予他人的证书。 需要使用作用域限定符“::”。

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

  • 数据库用户

  • 数据库角色

  • 应用程序角色

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

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

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

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

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

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

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

  • 数据库用户

  • 数据库角色

  • 应用程序角色

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

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

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

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

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

备注

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

证书权限 证书权限隐含的权限 数据库权限隐含的权限
CONTROL CONTROL CONTROL
TAKE OWNERSHIP CONTROL CONTROL
ALTER CONTROL ALTER ANY CERTIFICATE
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)
加密层次结构