Delphi-PRAXiS

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Datenbanken (https://www.delphipraxis.net/15-datenbanken/)
-   -   Delphi Verwendung der gleiche Komponente an mehr als 100 Stellen (https://www.delphipraxis.net/65235-verwendung-der-gleiche-komponente-mehr-als-100-stellen.html)

Karstadt 14. Mär 2006 08:40

Datenbank: MYSQL • Version: 4.1 • Zugriff über: Direkt

Verwendung der gleiche Komponente an mehr als 100 Stellen
 
Delphi-Quellcode:
  with dm.mqr_TEMP do
  begin
    Close;
    Sql.Clear;
    sql.Add('SELECT * FROM lager ORDER BY lg_bezeichnung ASC');
    open;
    While not Eof do
    begin
      Lagerliste.Add(Fieldbyname('lg_bezeichnung').asstring);
      next;
    end;
    close
Um Irgendwelche Daten zu bekommen. Z.b akkueller Benutzername; Lagername oder sonst was verwende ich immer die Komponente mqr_TEMP (obe ist nur ein Beispiel von 100) soll ich damit rechnen das dieses Vorgehen irgendwann fehlschlägt. Weil z.B. bei einigen Stellen onCalcfield ich auch diese Komponente mqr_TEMP arbeite.

:stupid:

mschaefer 14. Mär 2006 09:13

Re: Verwendung der gleiche Komponente an mehr als 100 Stelle
 
Geht,

solange Du nur liest und nicht mit Threads arbeitest. Bei Threads mußt Du jeweils eine eigenen Instanz aufbauen. Bei Schreibzugriffen mit Transaktionen arbeiten

//Grüße Martin

alzaimar 14. Mär 2006 09:17

Re: Verwendung der gleiche Komponente an mehr als 100 Stelle
 
Ja, Du sollst damit rechnen. Und deshalb wirst Du Dir keine Events für diese 'DatasetToStringList'-Query dazuschreiben und kein OnCalcFields.

Oder, Du sorgst dafür, das Deine Routinen reentrant sind, also den Laden genauso hinterlassen, wie sie ihn vorgefunden haben, übrigens ein simpler Trick, um robuste Programme zu schreiben:
Delphi-Quellcode:
Procedure SQLToStringList (Const anSQLStmt : String; aStringList : TStrings);
Begin
  SetupEventsAndCalculatedFieldsBlaBla; // Irgendwie die Events setzen und Veränderungen vornehmen
  Try
    With MyDataModule.TempQuery Do Begin
      SQL.Text := anSQLStmt;
      Active := True;
      First;
      While Not Eof Do Begin
        aStringList.Add (Fields[0].Value);
        Next;
      End;
    End;
  Finally
     ResetEventsAndCalculatedFieldsBlaBla; // Alle Änderungen wieder rückgängig machen
  End;
End;

Karstadt 14. Mär 2006 09:28

Re: Verwendung der gleiche Komponente an mehr als 100 Stelle
 
Ja aber beim Auruf leere ich die Tabelle bzw die SQL Anweisung:

Delphi-Quellcode:
with dm.mqr_TEMP do
  begin
    Close;
    Sql.Clear;

alzaimar 14. Mär 2006 09:51

Re: Verwendung der gleiche Komponente an mehr als 100 Stelle
 
Delphi-Quellcode:
MyQuery.SQL.Text := 'Select * From Foobar'
ist äquivalent mit
Delphi-Quellcode:
MyQuery.Close;
MyQuery.SQL.Clear;
MyQuera.SQL.Add('Select * From Foobar');


Alle Zeitangaben in WEZ +1. Es ist jetzt 15:24 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 by Thomas Breitkreuz