AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Delphi Verwendung der gleiche Komponente an mehr als 100 Stellen
Thema durchsuchen
Ansicht
Themen-Optionen

Verwendung der gleiche Komponente an mehr als 100 Stellen

Ein Thema von Karstadt · begonnen am 14. Mär 2006 · letzter Beitrag vom 14. Mär 2006
Antwort Antwort
Karstadt

Registriert seit: 8. Nov 2005
788 Beiträge
 
#1

Verwendung der gleiche Komponente an mehr als 100 Stellen

  Alt 14. Mär 2006, 08:40
Datenbank: MYSQL • Version: 4.1 • Zugriff über: Direkt
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.

  Mit Zitat antworten Zitat
Benutzerbild von mschaefer
mschaefer

Registriert seit: 4. Feb 2003
Ort: Hannover
2.032 Beiträge
 
Delphi 12 Athens
 
#2

Re: Verwendung der gleiche Komponente an mehr als 100 Stelle

  Alt 14. Mär 2006, 09:13
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
Martin Schaefer
  Mit Zitat antworten Zitat
alzaimar
(Moderator)

Registriert seit: 6. Mai 2005
Ort: Berlin
4.956 Beiträge
 
Delphi 2007 Enterprise
 
#3

Re: Verwendung der gleiche Komponente an mehr als 100 Stelle

  Alt 14. Mär 2006, 09:17
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;
"Wenn ist das Nunstruck git und Slotermeyer? Ja! Beiherhund das Oder die Flipperwaldt gersput!"
(Monty Python "Joke Warefare")
  Mit Zitat antworten Zitat
Karstadt

Registriert seit: 8. Nov 2005
788 Beiträge
 
#4

Re: Verwendung der gleiche Komponente an mehr als 100 Stelle

  Alt 14. Mär 2006, 09:28
Ja aber beim Auruf leere ich die Tabelle bzw die SQL Anweisung:

Delphi-Quellcode:
with dm.mqr_TEMP do
  begin
    Close;
    Sql.Clear;
  Mit Zitat antworten Zitat
alzaimar
(Moderator)

Registriert seit: 6. Mai 2005
Ort: Berlin
4.956 Beiträge
 
Delphi 2007 Enterprise
 
#5

Re: Verwendung der gleiche Komponente an mehr als 100 Stelle

  Alt 14. Mär 2006, 09:51
MyQuery.SQL.Text := 'Select * From Foobar' ist äquivalent mit
Delphi-Quellcode:
MyQuery.Close;
MyQuery.SQL.Clear;
MyQuera.SQL.Add('Select * From Foobar');
"Wenn ist das Nunstruck git und Slotermeyer? Ja! Beiherhund das Oder die Flipperwaldt gersput!"
(Monty Python "Joke Warefare")
  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 19:45 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