Delphi-PRAXiS

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Datenbanken (https://www.delphipraxis.net/15-datenbanken/)
-   -   Delphi Unterschied Fields[0] zu FieldByName(xy) (https://www.delphipraxis.net/96359-unterschied-fields%5B0%5D-zu-fieldbyname-xy.html)

TomDooley 23. Jul 2007 08:15

Datenbank: MS SQLServer • Version: 2000 • Zugriff über: ADO

Unterschied Fields[0] zu FieldByName(xy)
 
Hallo

In einer Applikation hatte ich zwischenzeitlich das Problem, dass eine Datenbankabfrage nicht funktionierte. Das SQL-Statement ist:
Delphi-Quellcode:
SELECT TOP 1 FeldXY FROM Tabelle1
Die Anweisung
Delphi-Quellcode:
FieldByName(FeldXY).asInteger;
hat dabei jeweis eine Exception ausgelöst: "...FeldXY nicht vorhanden..." (oder so ähnlich).

Ich habe nun die Anweisung wie folgt angepasst:
Delphi-Quellcode:
Fields[0].AsInteger
Nun funktioniert zwar alles ich kann mir aber nicht erklären warum... Kann mir jemand weiterhelfen?

SirThornberry 23. Jul 2007 08:20

Re: Unterschied Fields[0] zu FieldByName(xy)
 
durch "TOP 1 FeldXY" wird eventuell das Feld nicht als 'FeldXY' zurück gegeben. Da gibt es aber eine Anweisung mit der du angeben kannst unter welchem Namen das zurück gegeben wird (ich glaub "as 'rueckgabename'")

TomDooley 23. Jul 2007 08:30

Re: Unterschied Fields[0] zu FieldByName(xy)
 
Ich muss vielleicht noch ergänzen dass ich mehrere Instanzen dieser Applikation habe laufen lassen. Dabei hat es machmal auch funktioniert...

hoika 24. Jul 2007 09:05

Re: Unterschied Fields[0] zu FieldByName(xy)
 
Hallo,

wie schon geschrieben, als Bsp.

Select Count(*) As MySum From Table1.

Durch das As sagst du dem SQL-Server,
dass er das Feld "Umbenennen" soll.

Du kannst jetzt per Fields[0].AsInteger oder durch FieldByName('MySum').AsInteger
drauf zugreifen.

Das Fields[0] ist hier einfach schneller,
weil FieldByName intern eine Schleife ist,
die das Feld über den Name sucht.

Wenn ich schneller sage, muss man allerdings das relativ sehen,
die Schleife macht lokal einen Stringvergleich.
Gemessen an den SQLKosten (Query) Netzwerk-Kosten (Traffic)
sollte es verschwindend gering sein.

Ich persönlich benutzen Fields[0] genau dann,
wenn das Ergebnis nur ein Feld ist.
Bei allen anderen Sachen nehme ich FieldByName,
weil dadurch sichergestellt ist, das ich in meinem Code
keinen Fehler (zumindestens in dieser Hinsicht) habe.

Ändert sich z.B. eine Query und ich vergesse das an einer Stelle,
findet das mein dunit sofort raus, bei Fields kann an der betrreffenden
Stelle ja wer weiss was stehen.


Heiko

TomDooley 24. Jul 2007 09:45

Re: Unterschied Fields[0] zu FieldByName(xy)
 
Ich habe das mal ausprobiert. Im SQL Query Analyzer bekomme ich das gewünschte Resultat wenn ich folgendes Statement ausführe:
SQL-Code:
SELECT TOP 1 FeldXY from Tabelle1
Wenn ich jedoch 'AS' verwende bekomme ich einen Fehler:
SQL-Code:
SELECT TOP 1 AS FeldXY from Tabelle1
Zitat:

Falsche Syntax in der Nähe des AS-Schlüsselwortes.

DeddyH 24. Jul 2007 09:46

Re: Unterschied Fields[0] zu FieldByName(xy)
 
SQL-Code:
SELECT TOP 1 FeldXY AS einAlias from Tabelle1

TomDooley 24. Jul 2007 09:48

Re: Unterschied Fields[0] zu FieldByName(xy)
 
:oops: jetzt hab ich es auch kapiert...


Alle Zeitangaben in WEZ +1. Es ist jetzt 03:19 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