AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Delphi Access alternative für Paradox?
Thema durchsuchen
Ansicht
Themen-Optionen

Access alternative für Paradox?

Offene Frage von "kolio"
Ein Thema von Plague · begonnen am 13. Feb 2005 · letzter Beitrag vom 3. Mär 2005
Antwort Antwort
kolio

Registriert seit: 30. Jan 2005
Ort: Plauen
9 Beiträge
 
#1

Re: Access alternative für Paradox?

  Alt 28. Feb 2005, 17:19
Danke "ak1",

mit SQL ist funktioniert das Ganze etwa um den Faktor 2,5 schneller.

Delphi-Quellcode:
procedure TForm1.Button26Click(Sender: TObject);
var
  i,
  SerNr,
  SerSt,
  Cnt: LongInt;
  SerTx: String;
begin
  // Max SerNr ermitteln -------------------------------------------------------
  ADOQuery1.Close;
  ADOQuery1.SQL.Text := 'Select max(SerNr) as maxSerNr From Tabelle1';
  ADOQuery1.Open;
  SerSt := ADOQuery1.FieldByName('maxSerNr').AsInteger;
  SerNr := SerSt;
  // Anzahl der Datensätze -----------------------------------------------------
  Cnt := StrToInt(Edit3.Text);
  // ---------------------------------------------------------------------------
  T1 := Time;
  for i := 0 to Cnt - 1 do
  begin
    inc(SerNr);
    SerTx := 'IKM' + RightStr('00000000' + IntToStr(SerNr), 8);
    ADOQuery1.Close;
    ADOQuery1.SQL.Text := 'INSERT INTO Tabelle1 (SerNr, SerTx) ' +
                          'VALUES (:PSerNr, :PSerTx)';
    ADOQuery1.Parameters.ParamByName('PSerNr').Value := SerNr;
    ADOQuery1.Parameters.ParamByName('PSerTx').Value := SerTx;
    ADOQuery1.ExecSQL;
  end;
  T2 := Time;
  // ---------------------------------------------------------------------------
  showMessage(IntToStr(Cnt) + ' Datensätze');
  showTime;
end;
Nun hab ich noch ein Problem, was mit "ADODataSet1.LookUp" zwar schneller funktioniert als mit SQL aber immer noch viel zu langsam. Ich muss 100000 Datensätze durchsuchen, welche Seriennummern in aufsteigender Reihenfolge enthalten. Es kann sein, das irgendwo dazwischen eine Seriennummer fehlt. Genau die muss ich herausfinden. Zum Durchsuchen von 20000 Datensätzen brauch ich mit "LookUp" ca. 2,7 Sekunden, mit SQL dauert es eine Ewigkeit.

Mit LookUp:

Delphi-Quellcode:
procedure TForm1.Button8Click(Sender: TObject);
var
  i, SerNr: LongInt;
  V: Variant;
begin
  SerNr := ADODataSet1.FieldByName('SerNr').AsInteger;
  T1 := Time;
  for i := 0 to 99999 do
  begin
    V := ADODataSet1.Lookup('SerNr', SerNr, 'SerNr');
    if not (VarType(V) in [varNull]) then
      inc(SerNr)
    else
      Break;
  end;
  T2 := Time;
  ShowTime;
  ShowMessage('Seriennummer: ' + IntToStr(SerNr));
end;
Mit SQL:

Delphi-Quellcode:
procedure TForm1.Button17Click(Sender: TObject);
begin
  T1 := Time;
  ADOQuery4.Close;
  ADOQuery4.SQL.Text := 'Select SerNr From Tabelle1 ' +
                        'Where (SerNr + 1) Not In (Select SerNr From Tabelle1)';
  ADOQuery4.Open;
  T2 := Time;
  ShowTime;
end;
  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 12:39 Uhr.
Powered by vBulletin® Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024-2025 by Thomas Breitkreuz