AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken MSSQL server + ADO = lahme Ente ????

MSSQL server + ADO = lahme Ente ????

Ein Thema von bernhard_LA · begonnen am 8. Feb 2012 · letzter Beitrag vom 10. Feb 2012
Antwort Antwort
Seite 2 von 2     12
bernhard_LA

Registriert seit: 8. Jun 2009
Ort: Bayern
1.120 Beiträge
 
Delphi 11 Alexandria
 
#11

AW: MSSQL server + ADO = lahme Ente ????

  Alt 9. Feb 2012, 12:13
wir haben eine TQuery mit 400K Elementen in der Ergebnismenge und eine Schleife


Delphi-Quellcode:
    


    Query.first

    
    Query.Next

      Zugiff auf die einzelnen Werte mit
  
       Query.FieldByname( .....)


    until query.EOF


ist FieldbyName die Performance Bremse ?
  Mit Zitat antworten Zitat
Benutzerbild von p80286
p80286

Registriert seit: 28. Apr 2008
Ort: Stolberg (Rhl)
6.659 Beiträge
 
FreePascal / Lazarus
 
#12

AW: MSSQL server + ADO = lahme Ente ????

  Alt 9. Feb 2012, 12:20
Sollte man meinen, aber lt Hilfe ist dies nicht der Fall. Aus irgendwelchengründen ist das iterieren durch die Felder etwas langsamer.
Wie schon mehrmals angesprechen überprüf einmal die Cursor.
Je nachdem welche Datenbank im Hintergrund werkelt hat das einige Auswirkungen auf Geschw./Speicherverbrauch.

Gruß
K-H
Programme gehorchen nicht Deinen Absichten sondern Deinen Anweisungen
R.E.D retired error detector
  Mit Zitat antworten Zitat
Iwo Asnet

Registriert seit: 11. Jun 2011
313 Beiträge
 
#13

AW: MSSQL server + ADO = lahme Ente ????

  Alt 9. Feb 2012, 17:06
FieldByName sucht jedesmal in der Feldliste nach dem Feld mit dem Namen...

Führe die Analyse im Server aus oder schreibe dir eine extended stored procedure. Wenn das Resultat keine Riesenmengen sind, ist das in jedem Fall die bessere Wahl.
  Mit Zitat antworten Zitat
einbeliebigername

Registriert seit: 24. Aug 2004
140 Beiträge
 
Delphi XE8 Professional
 
#14

AW: MSSQL server + ADO = lahme Ente ????

  Alt 10. Feb 2012, 09:25
Hallo,

Delphi-Quellcode:
    


    Query.first

    
    Query.Next

      Zugiff auf die einzelnen Werte mit
  
       Query.FieldByname( .....)


    until query.EOF
also FieldByName mit ein und derselben Spalte sollte man wirklich nicht innerhalb einer Schleife machen. Am besten zwischen Open und Close pro Spalte nur einmal FieldByName . Man kann ja nach dem Öffnen erst mal für jede Spalten, die man brauch, FieldByName aufrufen und das Ergebnis in einer Sinnvoll benannten Variable speichern und diese in der Schleife benutzen.

Und dann sag mal ist die Reihenfolge von First, Next, Zugriff und EOF wirklich so wie oben. Denn eigentlich müsste das so sein:
Delphi-Quellcode:
    Query.first
    while not Query.EOF do
    begin
      Zugriff auf die einzelnen Werte mit
      QueryField.…
    
      Query.Next
    end;
einbeliebigername.
  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 12:49 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