AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren

Mehrere ZQuerys

Ein Thema von MaxMara · begonnen am 28. Apr 2008 · letzter Beitrag vom 29. Apr 2008
Antwort Antwort
MaxMara

Registriert seit: 27. Apr 2004
Ort: Wien
77 Beiträge
 
Delphi 2007 Enterprise
 
#1

Mehrere ZQuerys

  Alt 28. Apr 2008, 12:46
Datenbank: MySQL • Version: 5.1 • Zugriff über: ZeosLib
Hallo!
Habe (wiedermal) zwei kleine Fragen. Diesmal wegen der ZQuery-Komponente:
1.) Ich möchte mehrere SQLs per onTimer-Event ausführen.
Wie geht man hier am besten vor? Erstellt man mehrere ZQuerys und weist man jedem davon ein SQL fix zu, oder löscht man das SQL per SQL.Clear raus und schreibt dann das andere hinein?
2.) Wenn ich das Query per ZQuery1.Open öffne und Daten ändern sich inzwischen in der DB - kann ich auf diese dann gleich zugreifen?

Hoffe meine Fragestellung ist nicht zu verwirrend.

Danke und grüße
Christian
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

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

Re: Mehrere ZQuerys

  Alt 28. Apr 2008, 12:48
Wenn die selben Abfragen öfters verwendet werden, würde ich eigene Komponenten verwenden.
Markus Kinzler
  Mit Zitat antworten Zitat
MaxMara

Registriert seit: 27. Apr 2004
Ort: Wien
77 Beiträge
 
Delphi 2007 Enterprise
 
#3

Re: Mehrere ZQuerys

  Alt 28. Apr 2008, 12:56
Danke mkinzler!
Die zweite Antwort habe ich gerade 'ergooglet': Ich muss (anscheined) mit ZQuery1.Refresh; die Daten aktualisieren.
Stimmt das?
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

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

Re: Mehrere ZQuerys

  Alt 28. Apr 2008, 13:15
Kommt zusätzlich auch noch auf das DBMS und de Transaktionseinstellungen (wenn vom DBMS unterstützt) an.
Markus Kinzler
  Mit Zitat antworten Zitat
MaxMara

Registriert seit: 27. Apr 2004
Ort: Wien
77 Beiträge
 
Delphi 2007 Enterprise
 
#5

Re: Mehrere ZQuerys

  Alt 28. Apr 2008, 13:56
in meinem Fall wäre das MySQL mit MyISAM als Storageengine. Also keine Transaktionen.
  Mit Zitat antworten Zitat
Benutzerbild von RavenIV
RavenIV

Registriert seit: 12. Jan 2005
Ort: Waldshut-Tiengen
2.875 Beiträge
 
Delphi 2007 Enterprise
 
#6

Re: Mehrere ZQuerys

  Alt 28. Apr 2008, 14:01
Du nimmst ein TDataModule und knallst dort 4 oder 20 ZQuerys drauf.
Dann gibts Du jedem Query einen anständigen Namen (Query1 bis Query20 sind keine Namen).
Nun kannst Du jedem Query ein SQL geben und die Daten halten, solange Du sie brauchst.
Klaus E.
Linux - das längste Text-Adventure aller Zeiten...
Wer nie Linux mit dem vi konfiguriert hat, der hat am Leben vorbei geklickt.
  Mit Zitat antworten Zitat
MaxMara

Registriert seit: 27. Apr 2004
Ort: Wien
77 Beiträge
 
Delphi 2007 Enterprise
 
#7

Re: Mehrere ZQuerys

  Alt 28. Apr 2008, 14:06
Danke für den Tipp - werd ich ausprobieren.

Zitat von RavenIV:
Nun kannst Du jedem Query ein SQL geben und die Daten halten, solange Du sie brauchst.
Nur werden die Daten von einem anderen Prozess dauernd geändert. Das heisst es kommen laufend mehr Datensätze hinzu.
Wenn ich die Querys offen lasse, werden sie nicht aktualisiert, oder?
  Mit Zitat antworten Zitat
hoika

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

Re: Mehrere ZQuerys

  Alt 29. Apr 2008, 08:04
Hallo,

das Verhalten ist normal (und auch so gewollt).
Ein Query zeigt die Daten an,
die zum Zeitpunkt des Query.Open in der Tabelle (dem SQL-Statement) sind.

Abhilfe schafft hier Close; Open; oder auch Refresh.

Zu der Frage mit den SQL.Clear;
Ich mache das genau so.
Warum soll ich für jedes Statement eine eigene Query benutzen ?

Ausnahme:
Die Query wird oft aufgerufen und ist parametrisiert (prepared query).
Zeos prepared die Query ja selber.
Prepare bringt (unter Firebird) ungefähr Faktor 2 Geschwindigkeit mehr.
Kommt aber immer auf den Kontext das Aufrufes an.

Heiko
Heiko
  Mit Zitat antworten Zitat
MaxMara

Registriert seit: 27. Apr 2004
Ort: Wien
77 Beiträge
 
Delphi 2007 Enterprise
 
#9

Re: Mehrere ZQuerys

  Alt 29. Apr 2008, 08:48
Danke Hoika,
meine Frage ist nun beantwortet.
Ich werde - weil es eigentlich nur 2 Querys sind - für jedes eine ZQuery verwenden, da es um einiges weniger an Arbeit ist und ich von der Performance her auch keine Probleme feststellen konnte.

Grüße
Christian
  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 19:37 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