AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Delphi Paradox7 Tabelle zurücksetzen
Thema durchsuchen
Ansicht
Themen-Optionen

Paradox7 Tabelle zurücksetzen

Ein Thema von scuby · begonnen am 4. Apr 2008 · letzter Beitrag vom 7. Apr 2008
Antwort Antwort
scuby

Registriert seit: 31. Jul 2005
122 Beiträge
 
#1

Paradox7 Tabelle zurücksetzen

  Alt 4. Apr 2008, 16:23
Datenbank: Paradox • Version: 7 • Zugriff über: DBE / SQL
Hallo zusammen,

ich denke diese Frage wurde sicherlich schon mal beantwortet, leider konnte ich über Suche nichts finden, daher habe ich einfach mal ein neues Topic aufgemacht...

Folgendes habe ich vor:

1.) Löschen aller Datensätze aus einer Paradox7 Tabelle
2.) Zurücksetzen der Tabellenid

Delphi-Quellcode:
begin
if Form1.Label4.Caption <> '2then showmessage('Sie sind nicht berechtigt diese Funktion zu nutzen!') else
begin
 if messagedlg('Sind sie sicher, dass Sie alle Daten loeschen wollen?',mtConfirmation, [mbYes, mbNo], 0) = mrYes then
 begin
  with Query1 do
  begin
    Close;
    SQL.Text := 'DELETE FROM Studenten';
    ExecSQL;
  end;
end;
end;
end;
Mein Code zum Löschen aller Datensätze sieht momentan wie oben gezeigt aus.
Wenn ich diese Prozedur ausführe, werden auch alle Datensätze gelöscht. Lege ich nun einen neuen Datensatz an, so wird die ID aber fortgeführt. Wie bekomme ich es hin, das die ID wieder bei 1 startet?

Bsp.:

1 alter Datensatz
2 alter Datensatz
3 alter Datensatz
4 alter Datensatz
5 alter Datensatz
6 alter Datensatz
LÖSCHUNG aller Daten
nun soll die ID wieder bei 1 anfange....

LG
Scuby
  Mit Zitat antworten Zitat
shmia

Registriert seit: 2. Mär 2004
5.508 Beiträge
 
Delphi 5 Professional
 
#2

Re: Paradox7 Tabelle zurücksetzen

  Alt 4. Apr 2008, 16:28
Die ID von AutoInc-Felder wird mit dem Löschen nicht zurückgesetzt.
Die Tabelle enthält einen internen Generator, der von Aussen nicht zugänglich ist.
Im Grunde ist das auch nicht nötig; Hauptsache die ID ist immer eindeutig.

Andernfalls gibt es 2 Möglichkeiten:
1.) AutoInc-Feld in ein normales Integer-Feld ändern (mit Datenbankoberfläche) und speichern
wieder zurück nach AutoInc-Feld ändern
2.) Tabelle komplett löschen und neu anlegen

Beide Methoden sind problematisch, wenn es Beziehungen zum ID-Feld gibt.
Andreas
  Mit Zitat antworten Zitat
Thanatos81
(Gast)

n/a Beiträge
 
#3

Re: Paradox7 Tabelle zurücksetzen

  Alt 4. Apr 2008, 16:44
Also wenn wirklich alle Datensätze gelöscht und das AutoInc wieder auf 1 gesetzt werden soll, würde ich auch definitiv zum Löschen der Tabelle und neu anlegen raten. Gerade bei vielen Datensätzen dürfte das auch schneller gehen und vor allem ist der Platz wieder frei. Denn Paradox-Tabellen schrumpfen nicht nach einem Löschvorgang, sondern erst wenn man die Tabellen "packt"m zumindest wenn ich mich noch recht erinnere.
  Mit Zitat antworten Zitat
Benutzerbild von DeddyH
DeddyH

Registriert seit: 17. Sep 2006
Ort: Barchfeld
27.542 Beiträge
 
Delphi 11 Alexandria
 
#4

Re: Paradox7 Tabelle zurücksetzen

  Alt 4. Apr 2008, 17:27
Wieso soll eigentlich die ID wieder zurückgesetzt werden?
Detlef
"Ich habe Angst vor dem Tag, an dem die Technologie unsere menschlichen Interaktionen übertrumpft. Die Welt wird eine Generation von Idioten bekommen." (Albert Einstein)
Dieser Tag ist längst gekommen
  Mit Zitat antworten Zitat
FrankJ28

Registriert seit: 7. Apr 2008
211 Beiträge
 
Delphi 11 Alexandria
 
#5

Re: Paradox7 Tabelle zurücksetzen

  Alt 7. Apr 2008, 18:12
Hallo,
ganz einfach, wenn man den Header einer Paradox-Tabelle kennt .

procedure ResetAutoInc(Dateiname:string);
var myStream : TFileStream;
buffer : LongInt;
begin
buffer:=0;
mystream:=TFileStream.Create(Dateiname,fmOpenWrite + fmShareExclusive);
mystream.Seek(73,soFromBeginning);
mystream.WriteBuffer(buffer,4);
mystream.free;
end;

Ciao
Frank
"Sage was du tust, und tue was du sagst"
Johannes Rau
  Mit Zitat antworten Zitat
Antwort Antwort


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 17:35 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