AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Delphi Unterschied Fields[0] zu FieldByName(xy)
Thema durchsuchen
Ansicht
Themen-Optionen

Unterschied Fields[0] zu FieldByName(xy)

Ein Thema von TomDooley · begonnen am 23. Jul 2007 · letzter Beitrag vom 24. Jul 2007
Antwort Antwort
TomDooley

Registriert seit: 26. Jan 2004
124 Beiträge
 
#1

Unterschied Fields[0] zu FieldByName(xy)

  Alt 23. Jul 2007, 08:15
Datenbank: MS SQLServer • Version: 2000 • Zugriff über: ADO
Hallo

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

Ich habe nun die Anweisung wie folgt angepasst: Fields[0].AsInteger Nun funktioniert zwar alles ich kann mir aber nicht erklären warum... Kann mir jemand weiterhelfen?
  Mit Zitat antworten Zitat
Benutzerbild von SirThornberry
SirThornberry
(Moderator)

Registriert seit: 23. Sep 2003
Ort: Bockwen
12.235 Beiträge
 
Delphi 2006 Professional
 
#2

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

  Alt 23. Jul 2007, 08:20
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'")
Jens
Mit Source ist es wie mit Kunst - Hauptsache der Künstler versteht's
  Mit Zitat antworten Zitat
TomDooley

Registriert seit: 26. Jan 2004
124 Beiträge
 
#3

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

  Alt 23. Jul 2007, 08:30
Ich muss vielleicht noch ergänzen dass ich mehrere Instanzen dieser Applikation habe laufen lassen. Dabei hat es machmal auch funktioniert...
  Mit Zitat antworten Zitat
hoika

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

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

  Alt 24. Jul 2007, 09:05
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
Heiko
  Mit Zitat antworten Zitat
TomDooley

Registriert seit: 26. Jan 2004
124 Beiträge
 
#5

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

  Alt 24. Jul 2007, 09:45
Ich habe das mal ausprobiert. Im SQL Query Analyzer bekomme ich das gewünschte Resultat wenn ich folgendes Statement ausführe:
SELECT TOP 1 FeldXY from Tabelle1 Wenn ich jedoch 'AS' verwende bekomme ich einen Fehler: SELECT TOP 1 AS FeldXY from Tabelle1
Zitat:
Falsche Syntax in der Nähe des AS-Schlüsselwortes.
  Mit Zitat antworten Zitat
Benutzerbild von DeddyH
DeddyH

Registriert seit: 17. Sep 2006
Ort: Barchfeld
27.542 Beiträge
 
Delphi 11 Alexandria
 
#6

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

  Alt 24. Jul 2007, 09:46
SELECT TOP 1 FeldXY AS einAlias from Tabelle1
Detlef
"Ich habe Angst vor dem Tag, an dem die Technologie unsere menschlichen Interaktionen übertrumpft. Die Welt wird eine Generation von Idioten bekommen." (Albert Einstein)
Dieser Tag ist längst gekommen
  Mit Zitat antworten Zitat
TomDooley

Registriert seit: 26. Jan 2004
124 Beiträge
 
#7

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

  Alt 24. Jul 2007, 09:48
jetzt hab ich es auch kapiert...
  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 09:44 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