AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Delphi Alle Datensätze in allen Tabellen löschen

Alle Datensätze in allen Tabellen löschen

Ein Thema von manfred_h · begonnen am 21. Apr 2010 · letzter Beitrag vom 22. Apr 2010
Antwort Antwort
manfred_h

Registriert seit: 4. Nov 2005
Ort: Basel
442 Beiträge
 
Delphi XE2 Enterprise
 
#1

Alle Datensätze in allen Tabellen löschen

  Alt 21. Apr 2010, 15:42
Datenbank: Firebird • Version: 2.1 • Zugriff über: Fibplus
Hallo zusammen

besteht eine Möglichkeit in einer DB alle Datensätze in allen Tabellen zu löschen?
Die DB beinhaltet viele Tabllen und manuell ist es ein wenig umständlich.

Danke für Eure Tipps.

Manfred
  Mit Zitat antworten Zitat
borwin

Registriert seit: 14. Sep 2006
Ort: Rostock
72 Beiträge
 
Delphi 2007 Enterprise
 
#2

Re: Alle Datensätze in allen Tabellen löschen

  Alt 21. Apr 2010, 15:57
Du musst alle Tabellennamen aus der Datenbank auslesen und dann ein
 DELETE FROM [Tabellenname] ausführen.
Wenn Du Referenzen zwischen den Tabellen hast (Was eigentlich sein soll) musst Du noch die Reihenfolge beachten.
Erst Detail dann Master. Andere Möglichkeit die Constrains entfernen vor dem Löschen und wieder neu anlegen.

Andere Variante einen Sript von Deinen Metadaten erstellen (Tool IBExpert)
Leere Datenbank anlegen und den Sript einspielen. Damit sind alle Tabellen leer.

Gruß Borwin
  Mit Zitat antworten Zitat
manfred_h

Registriert seit: 4. Nov 2005
Ort: Basel
442 Beiträge
 
Delphi XE2 Enterprise
 
#3

Re: Alle Datensätze in allen Tabellen löschen

  Alt 21. Apr 2010, 16:25
Hallo borwin

Zitat von borwin:
Andere Variante einen Sript von Deinen Metadaten erstellen (Tool IBExpert)
Leere Datenbank anlegen und den Sript einspielen. Damit sind alle Tabellen leer.
Danke für den Tipp.
Dies geht eindeutig am schnellsten.

Shalom
Manfred
  Mit Zitat antworten Zitat
Benutzerbild von s.h.a.r.k
s.h.a.r.k

Registriert seit: 26. Mai 2004
3.159 Beiträge
 
#4

Re: Alle Datensätze in allen Tabellen löschen

  Alt 21. Apr 2010, 16:28
TRUNCATE TABLE ist glaube schneller als das DELETE.

Bei Oracle kannst bzgl. den Constraints ein CASCADE CONSTRAINTS machen, um diese auszuhebeln.
»Remember, the future maintainer is the person you should be writing code for, not the compiler.« (Nick Hodges)
  Mit Zitat antworten Zitat
manfred_h

Registriert seit: 4. Nov 2005
Ort: Basel
442 Beiträge
 
Delphi XE2 Enterprise
 
#5

Re: Alle Datensätze in allen Tabellen löschen

  Alt 21. Apr 2010, 16:34
Zitat von s.h.a.r.k:
TRUNCATE TABLE ist glaube schneller als das DELETE.
Bei Oracle kannst bzgl. den Constraints ein CASCADE CONSTRAINTS machen, um diese auszuhebeln.
Danke auch für Deinen Tipp.

Shalom
Manfred
  Mit Zitat antworten Zitat
mjustin

Registriert seit: 14. Apr 2008
3.004 Beiträge
 
Delphi 2009 Professional
 
#6

Re: Alle Datensätze in allen Tabellen löschen

  Alt 21. Apr 2010, 17:35
Für Historiker: in InterBase gab es eine 'Backdoor' mit der man alle Daten löschen konnte:

Backdoor in Borlands Datenbank Interbase seit 1992
http://www.heise.de/newsticker/meldu...992-29859.html

Zitat:
"Zudem entdeckten die Firebird-Entwickler eine weitere versteckte Funktion in Interbase: Je nachdem, welche Parameter übergeben werden, kann sie den Interbase-Server zum Absturz bringen oder gleich die ganze Datenbank löschen. Offenbar hat Borland/Inprise diese Funktion 1994 für Testzwecke eingebaut und darauf bestanden, sie in künftigen Versionen beizubehalten." ...
Aber die ist in Firebird 2.1 nicht mehr vorhanden
Michael Justin
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

Registriert seit: 9. Dez 2005
Ort: Heilbronn
39.851 Beiträge
 
Delphi 11 Alexandria
 
#7

Re: Alle Datensätze in allen Tabellen löschen

  Alt 21. Apr 2010, 18:16
Diese war schon in der inoffiziellen Version von IB6 nicht mehr da und damit auch in der daraus entstandenen FireBird Versionen
Markus Kinzler
  Mit Zitat antworten Zitat
Benutzerbild von Chemiker
Chemiker

Registriert seit: 14. Aug 2005
1.858 Beiträge
 
Delphi 11 Alexandria
 
#8

Re: Alle Datensätze in allen Tabellen löschen

  Alt 21. Apr 2010, 18:34
Hallo manfred_h,

aber erst nach einen BACKUP und RESTORE ist die Datenbank verkleinert.

Bis bald Chemiker
wer gesund ist hat 1000 wünsche wer krank ist nur einen.
  Mit Zitat antworten Zitat
manfred_h

Registriert seit: 4. Nov 2005
Ort: Basel
442 Beiträge
 
Delphi XE2 Enterprise
 
#9

Re: Alle Datensätze in allen Tabellen löschen

  Alt 22. Apr 2010, 09:13
Hallo nochmals

@mjustin: Danke für die Historischen Hinweise.
@mkinzler: Danke auch Dir.
@Chemiker: Das ist gut zu wissen.

Shalom
Manfred
  Mit Zitat antworten Zitat
Themen-Optionen Thema durchsuchen
Thema durchsuchen:

Erweiterte Suche
Ansicht

Forumregeln

Es ist dir nicht erlaubt, neue Themen zu verfassen.
Es ist dir nicht erlaubt, auf Beiträge zu antworten.
Es ist dir nicht erlaubt, Anhänge hochzuladen.
Es ist dir nicht erlaubt, deine Beiträge zu bearbeiten.

BB-Code ist an.
Smileys sind an.
[IMG] Code ist an.
HTML-Code ist aus.
Trackbacks are an
Pingbacks are an
Refbacks are aus

Gehe zu:

Impressum · AGB · Datenschutz · Nach oben
Alle Zeitangaben in WEZ +1. Es ist jetzt 03:06 Uhr.
Powered by vBulletin® Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz