Der Unterschied zwischen TRUNCATE und DELETE in SQL
TRUNCATE und DELETE bieten zwei Optionen beim Löschen von Tabellendaten in SQL. Das Verständnis ihrer unterschiedlichen Eigenschaften ist entscheidend, um fundierte Entscheidungen treffen zu können.
Übersicht
Wenn das Ziel darin besteht, alle Zeilen in einer Tabelle schnell zu löschen, ohne Daten beizubehalten, ist TRUNCATE normalerweise schneller als DELETE. Allerdings sollten auch systemspezifische Faktoren berücksichtigt werden.
Anweisungstyp
TRUNCATE wird als DDL-Anweisung (Data Definition Language) klassifiziert, während DELETE eine DML-Anweisung (Data Manipulation Language) ist. Diese Unterscheidung beeinflusst ihr Verhalten in bestimmten Kontexten.
Commit und Rollback
Je nach Datenbankanbieter kann TRUNCATE möglicherweise rückgängig gemacht werden oder nicht. PostgreSQL und SQL*Server ermöglichen das Rollback von TRUNCATE, während Oracle es als festgeschriebenen Vorgang behandelt.
Weltraumrecycling
TRUNCATE gewinnt Speicherplatz zurück, indem es zugewiesene Datensegmente freigibt. DELETE hingegen behält den von gelöschten Zeilen belegten Platz bei.
Zeilenbereich
TRUNCATE löscht alle Zeilen in einer Tabelle, während DELETE basierend auf Bedingungen auf bestimmte Zeilen abzielen kann.
Objekttyp
TRUNCATE kann auf eine Tabelle oder einen gesamten Cluster (herstellerspezifisch) angewendet werden. DELETE funktioniert für Tabellen und Tabellen in einem Cluster.
Datenobjekt-ID
In Oracle hat DELETE keinen Einfluss auf die Datenobjekt-ID, aber TRUNCATE weist eine neue ID zu, sofern nicht zuvor Daten in die Tabelle eingefügt wurden.
Flashback (Oracle)
DELETE unterstützt Flashback, sodass Daten aus einem früheren Zustand wiederhergestellt werden können. TRUNCATE hingegen verhindert einen Rückblick auf den Zustand vor der Kürzung. Allerdings kann die FLASHBACK ARCHIVE-Funktion von Oracle 11gR2 dieses Problem lindern.
Berechtigungen
Die Möglichkeit, TRUNCATE-Berechtigungen zu erteilen, variiert je nach Anbieter. Oracle erfordert die DROP ANY TABLE-Berechtigung, während andere Systeme möglicherweise die Erteilung dieser Berechtigung an bestimmte Benutzer oder Rollen zulassen.
Index
TRUNCATE in Oracle aktiviert nicht verfügbare Indizes wieder. DELETE hat diesen Effekt nicht.
Fremdschlüssel
TRUNCATE kann nicht ausgeführt werden, wenn aktive Fremdschlüsselverweise auf die Tabelle vorhanden sind. Das Verhalten von DELETE hängt von der Konfiguration der Fremdschlüssel ab.
Auslöser
DDL-Trigger können durch TRUNCATE-Vorgänge aktiviert werden, während DML-Trigger nicht ausgelöst werden.
Fernausführung
In Oracle kann TRUNCATE nicht über eine Datenbankverknüpfung durchgeführt werden.
Identitätsspalte
In SQL*Server setzt TRUNCATE die Reihenfolge der IDENTITY-Spalten zurück, DELETE hingegen nicht.
Das obige ist der detaillierte Inhalt vonTRUNCATE vs. DELETE in SQL: Wann sollte ich welches verwenden?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!