AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Delphi Problem mit Datenbank zugriff

Problem mit Datenbank zugriff

Ein Thema von tmrxxoja · begonnen am 23. Mär 2008 · letzter Beitrag vom 23. Mär 2008
Antwort Antwort
tmrxxoja

Registriert seit: 16. Mär 2008
Ort: Helgoland
27 Beiträge
 
Delphi 7 Professional
 
#1

Problem mit Datenbank zugriff

  Alt 23. Mär 2008, 01:08
Datenbank: SQLite • Version: 2.8 • Zugriff über: Zeos
Moin Moin

ich habe da ein kleines Problem mit einer Funktion die ich zusammen gewürfelt habe

Delphi-Quellcode:
procedure TForm1.Button1Click(Sender: TObject);
var cPfad : string;
    cZielPfad : string;
    aListe : TStrings;
    n : integer;
    cTag : String;
    cMonat : String;
    cJahr : String;
    cMD5 : String;
    cSQL : String;
    cDateiPfad : String;
    zListe : TZQuery;
begin

  cPfad := 'o:\';
  cZielPfad := 'd:\bilder\';
  aliste := TStringList.Create;
  n := 1;

  Form1.zQuery1.SQL.Clear;
  Form1.zQuery1.SQL.Add('SELECT md5 FROM PfadBilder Group by md5');
  Form1.zQuery1.Open;

  zListe := Form1.zQuery1;
  zListe.First;

  While (Not zListe.Eof) Do begin

    inc(n);

    cMD5 := zListe.FieldByName('MD5').asString;
    cDateiPfad := DB_PFAD(cMD5);

    cTag := FormatDateTime('DD', GetTime(cDateiPfad));
    cMonat := FormatDateTime('MM', GetTime(cDateiPfad));
    cJahr := FormatDateTime('YYYY', GetTime(cDateiPfad));

    if not DirectoryExists(cZielPfad+cJahr) then begin
      MkDir(cZielPfad+cJahr);
    end;

    if not DirectoryExists(cZielPfad+cJahr+'\'+cMonat) then begin
      MkDir(cZielPfad+cJahr+'\'+cMonat);
    end;

    if not DirectoryExists(cZielPfad+cJahr+'\'+cMonat+'\'+cTag) then begin
      MkDir(cZielPfad+cJahr+'\'+cMonat+'\'+cTag);
    end;

    CopyFile(PChar(cDateiPfad), PChar(cZielPfad+cJahr+'\'+cMonat+'\'+cTag+'\'+inttostr(n)+'.jpg'), true);

    zListe.Next;

  end;

end;
tja hier rufe ich die Funktion DB_PFAD auf und hier ist auch das problem


Delphi-Quellcode:
function DB_PFAD(cString : String): String;
var cSQL : String;
begin

  Form1.zQuery1.SQL.Clear;

  cSQL := ' SELECT pfad FROM PfadBilder '
        + ' Where md5 = "'+ cString
        + '" ORDER By geaendert asc'
        + ' Limit 1';

  Form1.zQuery1.SQL.Add(cSQL);
  Form1.zQuery1.Open;

  Result := Form1.zQuery1.FieldByName('pfad').asString;

end;
wenn ich alles ausklammer läuft er die zListe durch
wenn ich die funktion DB_PFAD aufrufe ist er beim ersten Durchlauf fertig also muss da muss irgendwas in der DB_PFAD funktion die Query zListe auf EOF setzen
weil dann bricht er einfach ab

aber ich weiss nicht warum

weil er muss da mindestens 40 000 mal durchgehen
tut er aber nicht sondern wenn er einmal DB_PFAD ist zListe auf EOF

hmm kann da mal jemand einen blick reinwerfen
ich weiss nicht wo der fehler ist
  Mit Zitat antworten Zitat
hoika

Registriert seit: 5. Jul 2006
Ort: Magdeburg
8.270 Beiträge
 
Delphi 10.4 Sydney
 
#2

Re: Problem mit Datenbank zugriff

  Alt 23. Mär 2008, 07:39
Hallo,

du benutzt in DB_PATH Form1.zQuery1;

Diese Query benutzt du ebenfalls in Button1Click


Dein zListe := Form1.zQuery1; bringt nichts,
es ist trotzdem die gleiche Query.

Abhilfe: Nimm für DB_PATH eine zweite Query,
und benenn die gleich mal anständig , also nicht zQuery2


Heiko
Heiko
  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 16:05 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