Freigeben über


DROP ROLE (Transact-SQL)

Entfernt eine Rolle aus der Datenbank.

Themenlink (Symbol) 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.

VorsichtshinweisVorsicht

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

CREATE ROLE (Transact-SQL)

ALTER ROLE (Transact-SQL)

EVENTDATA (Transact-SQL)

sp_addrolemember (Transact-SQL)

sys.database_role_members (Transact-SQL)

sys.database_principals (Transact-SQL)

Sicherheitsfunktionen (Transact-SQL)

Konzepte

Prinzipale (Datenbankmodul)