AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Delphi SQL-Abfragen und Stored-Proc mit oder ohne Prepare?
Thema durchsuchen
Ansicht
Themen-Optionen

SQL-Abfragen und Stored-Proc mit oder ohne Prepare?

Ein Thema von HaJo · begonnen am 14. Dez 2005 · letzter Beitrag vom 14. Dez 2005
Antwort Antwort
HaJo

Registriert seit: 28. Apr 2004
Ort: Würselen
140 Beiträge
 
Delphi 8 Enterprise
 
#1

SQL-Abfragen und Stored-Proc mit oder ohne Prepare?

  Alt 14. Dez 2005, 12:34
Datenbank: Interbase • Version: 6.1 / 7.1 • Zugriff über: IB/BDE
Hallo an alle,

ich habe nur zwei kurze Fragen.
Zum einen: Ist es sinnvoll jedes SQL-Statement explizit mit "Prepare" vorzubereiten.
Zum Beispiel so:
Delphi-Quellcode:
   IF NOT QryTmpKunden.Prepared then
      QryTmpKunden.Prepare;
   QryTmpKunden.ExecSQL;

   //oder bei einer Stored Procedure..

   IF NOT DM3.StProcZF.Prepared then
      DM3.StProcZF.Prepare;
   DM3.StProcZF.ExecProc;
Zum anderen:
Wie verfährt man im eigenen Programm, wenn die SQL-Verbindung zum Server gestört ist, z.B. durch einen aus dem Tritt gekommenen Switch? Bei der BDE-Komponente ist nach einer einmal zustande gekommenden Verbindung keine Trennung mehr möglich. Es bleibt dann nur, die Anwendung gewaltsam abzuschiessen.
Dieses Verhalten ist, so glaube ich, nur bei Verwendung von NT2003 und XP-SP2 festzustellen.

Lieben Gruß an alle
Jochen
Hans-Joachim Brosius
  Mit Zitat antworten Zitat
noidic

Registriert seit: 21. Nov 2005
Ort: Mönchengladbach
25 Beiträge
 
Delphi 7 Enterprise
 
#2

Re: SQL-Abfragen und Stored-Proc mit oder ohne Prepare?

  Alt 14. Dez 2005, 12:39
Wenn ich mich recht entsinne gibts bei der BDE ein Problem mit prepare, aufgrund dessen man das nicht verwenden sollte.

Prepare macht generell auch nur da Sinn, wo ein und das selbe Statement mit unterschiedlichen Parametern aufgerufen wird, anosnten ist es nur eine schlichte Verlagerung der Zeit von einer Stell zur anderen.


Zur zweiten Frage: Dies ist ein echtes Problem, auf einen Timeout zu warten ist für die meisten Anwendungen nicht praktikabel. Eine mögliche Lösung wäre einen zweiten Thread zu haben, der per Ping o.ä. die Verwfügbarkeit des Servers prüft. Hilft aber auch nciht viel, wenn grad ne Abfrage läuft...
The light at the end of the tunnel may be an oncoming dragon.
  Mit Zitat antworten Zitat
Benutzerbild von Bernhard Geyer
Bernhard Geyer

Registriert seit: 13. Aug 2002
17.171 Beiträge
 
Delphi 10.4 Sydney
 
#3

Re: SQL-Abfragen und Stored-Proc mit oder ohne Prepare?

  Alt 14. Dez 2005, 12:44
[quote="HaJo"]Zum einen: Ist es sinnvoll jedes SQL-Statement explizit mit "Prepare" vorzubereiten.[/delphi]
Nur dann wenn das Statement (mit anderen Parametern) mehrfach verwendet wird.

Zitat von HaJo:
Bei der BDE-Komponente ist nach einer einmal zustande gekommenden Verbindung keine Trennung mehr möglich. Es bleibt dann nur, die Anwendung gewaltsam abzuschiessen.
Mal wieder ein Grund die BDE abzulößen.
Windows Vista - Eine neue Erfahrung in Fehlern.
  Mit Zitat antworten Zitat
HaJo

Registriert seit: 28. Apr 2004
Ort: Würselen
140 Beiträge
 
Delphi 8 Enterprise
 
#4

Re: SQL-Abfragen und Stored-Proc mit oder ohne Prepare?

  Alt 14. Dez 2005, 13:04
Vielen Dank Euch beiden für Eure Antwort - bestätigt meine Erfahrung.

Danke
Jochen
Hans-Joachim Brosius
  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 11:22 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