AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Thema durchsuchen
Ansicht
Themen-Optionen

Query SQL

Ein Thema von ilse2005 · begonnen am 29. Nov 2010 · letzter Beitrag vom 30. Nov 2010
Antwort Antwort
ilse2005

Registriert seit: 15. Nov 2010
8 Beiträge
 
#1

Query SQL

  Alt 29. Nov 2010, 20:49
Datenbank: Access • Version: 2010 • Zugriff über: ADO
Hallo,
ich habe ein Problem mit der TADOQuery Komponene von Delphi 7.
Mit folgender Procedure setze ich das Query:

Delphi-Quellcode:
procedure TFormMain.QuerySetzen();
var
  Query : TADOQuery;
begin
  Query := DataModule2.ADOQueryBuch;
  Query.Close;
  Query.SQL.Clear;
  Query.SQL.Add('SELECT Buch.Titel, Buch.Autor, Buch.Beschreibung, Buch.Bild, Buch.Gelesen, Buch.Benutzer, Buch.Monat, Buch.Jahr, Buch.Test ');
  Query.SQL.Add('FROM');
  Query.SQL.Add('Buch');



  Query.SQL.Add('Order by Jahr,Monat');
  Query.Open;
end;
Das Problem ist nun, wenn ich dies im OnFormCreate Event aufrufe werden die Felder "Beschreibung" und "Test" nicht geladen.
Wennn ich die gleiche procedur aber z.b durch einen Button aufrufe funktionier alles wunderbar.
Wo liegt das Problem?
  Mit Zitat antworten Zitat
Satty67

Registriert seit: 24. Feb 2007
Ort: Baden
1.566 Beiträge
 
Delphi 2007 Professional
 
#2

AW: Query SQL

  Alt 29. Nov 2010, 21:13
DataModule2 wird erst nach OnFormCreate richtig initialisiert, weshalb dann DataModule2.ADOQueryBuch keine korrekten Connection-Werte hält?

Bei Delphi7 gibt es noch kein Form.OnLoaded, evtl. statt OnFormCreate das Ereignis OnActivate verwenden. Da muss man einmalige Sachen allerdings Steuern (Wird ja u.U. mehrmals aufgerufen):

Form private (member) FFirstRun : Boolean; // im OnFormCreate auf true setzen .


und im OnActivate
Delphi-Quellcode:
if FFirstRun then
begin
  FFirstRun := false;
  // Init Code
end;

Geändert von Satty67 (29. Nov 2010 um 21:20 Uhr)
  Mit Zitat antworten Zitat
Benutzerbild von Sir Rufo
Sir Rufo

Registriert seit: 5. Jan 2005
Ort: Stadthagen
9.454 Beiträge
 
Delphi 10 Seattle Enterprise
 
#3

AW: Query SQL

  Alt 29. Nov 2010, 23:56
Bei Delphi7 gibt es noch kein Form.OnLoaded
Bei Delphi 2010 auch nicht ... oder überlese ich das konsequent?
Kaum macht man's richtig - schon funktioniert's
Zertifikat: Sir Rufo (Fingerprint: ‎ea 0a 4c 14 0d b6 3a a4 c1 c5 b9 dc 90 9d f0 e9 de 13 da 60)
  Mit Zitat antworten Zitat
Satty67

Registriert seit: 24. Feb 2007
Ort: Baden
1.566 Beiträge
 
Delphi 2007 Professional
 
#4

AW: Query SQL

  Alt 30. Nov 2010, 00:17
Ups, hab' da wohl was vermischt. Macht ja nix, für D7 bleibt es ja gleich.

Ist eine Variante für C#, die in OnLoad Application.Idle einem OnLoaded Handler zuweist (und dort gleich wieder entfernt). Bei Delphi wäre das wohl in etwa der erste Aufruf eines ActionList-Update. Denke aber für Delphi passt die alte Variante noch besser.
  Mit Zitat antworten Zitat
hoika

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

AW: Query SQL

  Alt 30. Nov 2010, 06:11
Hallo,

das FFirstRun kann man sich spoaren,
wenn man als letzten Befehl in FormActivate einfach

OnActivate:= NIL; schreibt.


Heiko
Heiko
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

Registriert seit: 9. Dez 2005
Ort: Heilbronn
39.851 Beiträge
 
Delphi 11 Alexandria
 
#6

AW: Query SQL

  Alt 30. Nov 2010, 06:30
Bei Delphi7 gibt es noch kein Form.OnLoaded
Bei Delphi 2010 auch nicht ... oder überlese ich das konsequent?
Die Methode heisst auch .Loaded()
Markus Kinzler
  Mit Zitat antworten Zitat
Benutzerbild von toms
toms
(CodeLib-Manager)

Registriert seit: 10. Jun 2002
4.648 Beiträge
 
Delphi XE Professional
 
#7

AW: Query SQL

  Alt 30. Nov 2010, 06:41
Hallo,

das FFirstRun kann man sich spoaren,
wenn man als letzten Befehl in FormActivate einfach

OnActivate:= NIL; schreibt.
Gute Idee ... aber natürlich nur dann, wenn das OnActivate Ereignis später nicht mehr gebraucht wird.
Thomas
  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 03:02 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