DROP ROLE (Transact-SQL)
Quita un rol de la base de datos.
Sintaxis
DROP ROLE role_name
Argumentos
- role_name
Especifica el rol que se va a quitar de la base de datos.
Comentarios
Los roles que tienen elementos protegibles no se quitan de la base de datos. Para quitar un rol de base de datos que tiene elementos protegibles, primero debe transferir la propiedad de esos elementos protegibles o quitarlos de la base de datos. Los roles tienen miembros que no se pueden quitar de la base de datos. Para quitar un rol que tiene miembros, primero debe eliminar los miembros del rol.
No puede utilizar DROP ROLE para quitar una función de base de datos fija.
La información sobre la pertenencia a funciones se puede ver en la vista de catálogo sys.database_role_members.
Advertencia |
---|
El comportamiento de los esquemas cambió en SQL Server 2005. En consecuencia, el código que supone que los esquemas son equivalentes a los usuarios de base de datos puede dejar de devolver resultados correctos. Las antiguas vistas de catálogo, incluida sysobjects, no se deben usar en una base de datos en la que se haya utilizado alguna vez cualquiera de las siguientes instrucciones DDL: CREATE SCHEMA, ALTER SCHEMA, DROP SCHEMA, CREATE USER, ALTER USER, DROP USER, CREATE ROLE, ALTER ROLE, DROP ROLE, CREATE APPROLE, ALTER APPROLE, DROP APPROLE, ALTER AUTHORIZATION. En esas bases de datos, debe usar las nuevas vistas de catálogo. En las nuevas vistas de catálogo se tiene en cuenta la separación de entidades de seguridad y esquemas que se estableció en SQL Server 2005. Para obtener más información sobre las vistas de catálogo, vea Vistas de catálogo (Transact-SQL). |
Permisos
Requiere el permiso ALTER ANY ROLE en la base de datos o el permiso CONTOL en la función, o la pertenencia a db_securityadmin.
Ejemplos
En el ejemplo siguiente se quita la función de base de datos purchasing de AdventureWorks2008R2.
USE AdventureWorks2008R2;
DROP ROLE purchasing;
GO