DROP ROLE (Transact-SQL)
Entfernt eine Rolle aus der Datenbank.
Transact-SQL-Syntaxkonventionen
Syntax
DROP ROLE role_name
Argumente
- role_name
Gibt die Rolle an, die aus der Datenbank gelöscht werden soll.
Hinweise
Rollen, die sicherungsfähige Elemente besitzen, können nicht aus der Datenbank gelöscht werden. Wenn eine Datenbankrolle mit sicherungsfähigen Elementen gelöscht werden soll, müssen Sie zunächst den Besitz dieser sicherungsfähigen Elemente übertragen oder sie aus der Datenbank löschen. Rollen mit Mitgliedern können nicht aus der Datenbank gelöscht werden. Zum Löschen einer Rolle mit Mitgliedern müssen Sie zunächst die Mitglieder der Rolle entfernen.
Mit ALTER ROLE (Transact-SQL) können Sie Mitglieder aus einer Datenbankrolle entfernen.
DROP ROLE kann nicht zum Löschen einer festen Datenbankrolle verwendet werden.
Informationen zur Rollenmitgliedschaft können in der sys.database_role_members-Katalogsicht angezeigt werden.
Vorsicht |
---|
Mit SQL Server 2005 wurde das Verhalten von Schemas geändert. Deshalb werden von Code, der voraussetzt, dass Schemas und Datenbankbenutzer äquivalent sind, möglicherweise keine richtigen Ergebnisse mehr zurückgegeben. Alte Katalogsichten, einschließlich sysobjects, sollten nicht in einer Datenbank verwendet werden, in der bereits eine der folgenden DDL-Anweisungen verwendet wurde: 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. In solchen Datenbanken müssen Sie stattdessen neue Katalogsichten verwenden. In den neuen Katalogsichten wird die Trennung zwischen Prinzipalen und Schemas berücksichtigt, die in SQL Server 2005 eingeführt wurde. Weitere Informationen zu Katalogsichten finden Sie unter Katalogsichten (Transact-SQL). |
Zum Entfernen einer Serverrolle verwenden Sie DROP SERVER ROLE (Transact-SQL).
Berechtigungen
Erfordert die ALTER ANY ROLE-Berechtigung für die Datenbank, die CONTOL-Berechtigung für die Rolle oder die Mitgliedschaft in der db_securityadmin.
Beispiele
Im folgenden Beispiel wird die Datenbankrolle purchasing aus AdventureWorks2012 entfernt.
USE AdventureWorks2012;
DROP ROLE purchasing;
GO
Siehe auch
Verweis
sp_addrolemember (Transact-SQL)
sys.database_role_members (Transact-SQL)
sys.database_principals (Transact-SQL)
Sicherheitsfunktionen (Transact-SQL)