DENY 程序集权限 (Transact-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 选项,则指定的主体必须拥有程序集。