DENY 程序集权限 (Transact-SQL)

拒绝对程序集的权限。

适用范围:SQL Server(SQL Server 2008 到当前版本)。

主题链接图标 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)

概念

权限(数据库引擎)

主体(数据库引擎)

加密层次结构