Alexander Bier

  • Über mich
  • Journey
  • Portfolio
  • Blog
  • Kontakt

Alexander Bier

  • Über mich
  • Journey
  • Portfolio
  • Blog
  • Kontakt

Soft Deletes vs Hard Deletes

Alexander
27. April 2026
Best Practice, Softwareentwicklung

Eine Architekturentscheidung mit langfristigen Folgen

Das Löschen von Daten wirkt auf den ersten Blick trivial. Ein Datensatz wird entfernt und das Problem ist erledigt.

In der Praxis ist die Entscheidung zwischen Soft Delete und Hard Delete jedoch eine derjenigen, die langfristig die Komplexität eines Systems stark beeinflusst.

Was ist der Unterschied?

Beim Hard Delete wird ein Datensatz physisch aus der Datenbank entfernt.

Beim Soft Delete bleibt der Datensatz erhalten und wird stattdessen als gelöscht markiert, typischerweise durch ein Feld wie deleted_at oder is_deleted.

Beide Ansätze lösen das gleiche Problem auf unterschiedliche Weise, mit sehr unterschiedlichen Konsequenzen.

Hard Delete: Einfach, aber endgültig

Hard Deletes sind technisch unkompliziert.

  • Keine zusätzlichen Bedingungen in Queries
  • Keine versteckten Datensätze
  • Klare Datenbasis

Der Preis dafür ist der Verlust von Information.

  • Keine Wiederherstellung möglich
  • Keine Historie
  • Referenzen können brechen

Hard Deletes sind dann sinnvoll, wenn Daten wirklich keine Bedeutung mehr haben oder bewusst entfernt werden müssen.

Soft Delete: Flexibel, aber komplex

Soft Deletes bieten mehr Kontrolle über Daten, führen aber zu zusätzlicher Komplexität.

  • Daten können wiederhergestellt werden
  • Historie bleibt erhalten
  • Referenzen bleiben konsistent

Diese Vorteile kommen mit klaren Nachteilen:

  • Jede Query muss den Löschstatus berücksichtigen
  • Fehler durch „vergessene Filter“ sind häufig
  • Daten wachsen kontinuierlich weiter

Das System wirkt stabil, wird aber mit der Zeit schwerer zu kontrollieren.

Der häufigste Fehler: Soft Delete ohne Strategie

In vielen Systemen wird Soft Delete eingeführt, ohne die langfristigen Konsequenzen zu berücksichtigen.

Typische Probleme:

  • Inkonsistente Filterlogik über verschiedene Services hinweg
  • „Gelöschte“ Daten tauchen unerwartet wieder auf
  • Unklare Regeln, wann Daten endgültig entfernt werden

Das führt dazu, dass das System zwei Zustände verwalten muss: sichtbar und unsichtbar, ohne klare Trennung.

Technische Auswirkungen im Detail

Queries:
Soft Deletes erfordern zusätzliche Bedingungen in fast jeder Abfrage. Das erhöht die Komplexität und kann Performance beeinflussen.

Indizes:
Indizes müssen oft den Löschstatus berücksichtigen, was ihre Effektivität verändern kann.

Constraints:
Unique Constraints funktionieren nicht mehr wie erwartet, da „gelöschte“ Daten weiterhin existieren.

Referenzen:
Foreign Keys bleiben bestehen, was einerseits hilfreich ist, andererseits unerwartete Abhängigkeiten verlängert.

Wann welcher Ansatz sinnvoll ist

Hard Delete eignet sich, wenn:

  • Daten keine langfristige Bedeutung haben
  • Speicher und Klarheit wichtiger sind als Historie
  • rechtliche Anforderungen Löschung erzwingen

Soft Delete eignet sich, wenn:

  • Daten wiederherstellbar sein müssen
  • Auditing oder Historie wichtig ist
  • Beziehungen zwischen Daten erhalten bleiben sollen

Best Practices aus der Praxis

  • Klare Konvention für Löschfelder definieren (z. B. deleted_at statt Boolean)
  • Zentrale Query-Filter verwenden (z. B. Repository-Layer)
  • Strategie für endgültige Löschung festlegen (z. B. Cleanup-Jobs)
  • Soft Deletes nicht als Default verwenden, sondern bewusst entscheiden

Fazit

Die Entscheidung zwischen Soft Delete und Hard Delete ist keine Implementierungsfrage, sondern eine Architekturentscheidung.

Hard Delete reduziert Komplexität, verliert aber Information.

Soft Delete erhält Information, erhöht aber systemweite Komplexität.

Die richtige Wahl hängt nicht von technischer Präferenz ab, sondern davon, welche Kosten man langfristig tragen möchte.

Schreibe einen Kommentar Antwort abbrechen

Deine E-Mail-Adresse wird nicht veröffentlicht. Erforderliche Felder sind mit * markiert

  • Willkommen auf meinem Blog!

    Willkommen auf meinem Blog!

    Allgemein
  • Soft Deletes vs Hard Deletes

    Soft Deletes vs Hard Deletes

    Best Practice, Softwareentwicklung
  • Die unsichtbaren Kosten guter Architekturentscheidungen

    Die unsichtbaren Kosten guter Architekturentscheidungen

    Projektmanagement, Softwareentwicklung
  • Dev vs Consultant

    Dev vs Consultant

    Softwareentwicklung
  • Die Illusion von Produktivität

    Die Illusion von Produktivität

    Allgemein
  • Das Problem mit zu frühen Abstraktionen

    Das Problem mit zu frühen Abstraktionen

    Softwareentwicklung

Agile Aktien Barrierefreiheit Buchvorstellung Bücher Consulting Cost-Average-Effekt Digitalisierung Digitalisierungstrategie Docker Einstieg Entscheidungsfindung Erklärung ETF Finanzen Gaming GCS Go Index Indizes Kanban Kassensystem Kosten-Nutzen-Analyse Messe MFN Berlin Museum für Naturkunde Nato Persönliche Weiterentwicklung Portfolio Projektmanagement Prozessautomatisierung Scrum Softwareentwicklung Spreads SWOT-Analyse Szenarioanalyse Toto Guillaume vue Wasserfallmodell ZDE Zweck der Existenz

© 2023

Alexander Bier

  • Startseite
  • Datenschutz
  • Impressum
  • Kontakt
Zustimmung verwalten
Um dir ein optimales Erlebnis zu bieten, verwenden wir Technologien wie Cookies, um Geräteinformationen zu speichern und/oder darauf zuzugreifen. Wenn du diesen Technologien zustimmst, können wir Daten wie das Surfverhalten oder eindeutige IDs auf dieser Website verarbeiten. Wenn du deine Zustimmung nicht erteilst oder zurückziehst, können bestimmte Merkmale und Funktionen beeinträchtigt werden.
Funktional Immer aktiv
Die technische Speicherung oder der Zugang ist unbedingt erforderlich für den rechtmäßigen Zweck, die Nutzung eines bestimmten Dienstes zu ermöglichen, der vom Teilnehmer oder Nutzer ausdrücklich gewünscht wird, oder für den alleinigen Zweck, die Übertragung einer Nachricht über ein elektronisches Kommunikationsnetz durchzuführen.
Vorlieben
Die technische Speicherung oder der Zugriff ist für den rechtmäßigen Zweck der Speicherung von Präferenzen erforderlich, die nicht vom Abonnenten oder Benutzer angefordert wurden.
Statistiken
Die technische Speicherung oder der Zugriff, der ausschließlich zu statistischen Zwecken erfolgt. Die technische Speicherung oder der Zugriff, der ausschließlich zu anonymen statistischen Zwecken verwendet wird. Ohne eine Vorladung, die freiwillige Zustimmung deines Internetdienstanbieters oder zusätzliche Aufzeichnungen von Dritten können die zu diesem Zweck gespeicherten oder abgerufenen Informationen allein in der Regel nicht dazu verwendet werden, dich zu identifizieren.
Marketing
Die technische Speicherung oder der Zugriff ist erforderlich, um Nutzerprofile zu erstellen, um Werbung zu versenden oder um den Nutzer auf einer Website oder über mehrere Websites hinweg zu ähnlichen Marketingzwecken zu verfolgen.
  • Optionen verwalten
  • Dienste verwalten
  • Verwalten von {vendor_count}-Lieferanten
  • Lese mehr über diese Zwecke
Einstellungen ansehen
  • {title}
  • {title}
  • {title}