DENY Assembly Permissions (Transact-SQL)

THIS TOPIC APPLIES TO:yesSQL Server (starting with 2008)noAzure SQL DatabasenoAzure SQL Data Warehouse noParallel Data Warehouse

Denies permissions on an assembly.

Topic link icon Transact-SQL Syntax Conventions

Syntax


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

Arguments

permission
Specifies a permission that can be denied on an assembly. Listed below.

ON ASSEMBLY ::assembly_name
Specifies the assembly on which the permission is being denied. The scope qualifier "::" is required.

database_principal
Specifies the principal to which the permission is being denied. One of the following:

  • database user

  • database role

  • application role

  • database user mapped to a Windows login

  • database user mapped to a Windows group

  • database user mapped to a certificate

  • database user mapped to an asymmetric key

  • database user not mapped to a server principal.

    CASCADE
    Indicates that the permission being denied is also denied to other principals to which it has been granted by this principal.

    denying_principal
    Specifies a principal from which the principal executing this query derives its right to deny the permission. One of the following:

  • database user

  • database role

  • application role

  • database user mapped to a Windows login

  • database user mapped to a Windows group

  • database user mapped to a certificate

  • database user mapped to an asymmetric key

  • database user not mapped to a server principal.

Remarks

An assembly is a database-level securable contained by the database that is its parent in the permissions hierarchy. The most specific and limited permissions that can be denied on an assembly are listed below, together with the more general permissions that include them by implication.

Assembly permission Implied by assembly permission Implied by database permission
CONTROL CONTROL CONTROL
TAKE OWNERSHIP CONTROL CONTROL
ALTER CONTROL ALTER ANY ASSEMBLY
REFERENCES CONTROL REFERENCES
VIEW DEFINITION CONTROL VIEW DEFINITION

Permissions

Requires CONTROL permission on the assembly. If using the AS option, the specified principal must own the assembly.

See Also

DENY (Transact-SQL)
Permissions (Database Engine)
Principals (Database Engine)
CREATE CERTIFICATE (Transact-SQL)
CREATE ASYMMETRIC KEY (Transact-SQL)
CREATE APPLICATION ROLE (Transact-SQL)
CREATE ASSEMBLY (Transact-SQL)
Encryption Hierarchy