AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Weiterverwenden eines erechneten Feldes
Thema durchsuchen
Ansicht
Themen-Optionen

Weiterverwenden eines erechneten Feldes

Ein Thema von knochen · begonnen am 15. Jun 2010 · letzter Beitrag vom 15. Jun 2010
Antwort Antwort
knochen

Registriert seit: 26. Aug 2009
81 Beiträge
 
Delphi 2006 Professional
 
#1

Weiterverwenden eines erechneten Feldes

  Alt 15. Jun 2010, 14:30
Datenbank: MSSQL • Version: 2005 • Zugriff über: direkt
Hallo zusammen,

wie kann ich ein mit AS erzeugtes Feld weiterverwenden?

Das SQL Statement dazu:
SELECT EinIntegerFeld as test, test * 5 FROM Tabellenname

Wenn ich dieses Statement absetze, erscheint der Fehler Ungültiger Spaltenname 'test'.

Vielen Dank für jeden Tipp.
A fool with a tool remains a fool.
  Mit Zitat antworten Zitat
EarlyBird

Registriert seit: 29. Mär 2007
235 Beiträge
 
#2

AW: Weiterverwenden eines erechneten Feldes

  Alt 15. Jun 2010, 14:39
versuch es mal so:
Code:
SELECT EinIntegerFeld as test, EinIntegerFeld * 5 as Test2 FROM Tabellenname
  Mit Zitat antworten Zitat
knochen

Registriert seit: 26. Aug 2009
81 Beiträge
 
Delphi 2006 Professional
 
#3

AW: Weiterverwenden eines erechneten Feldes

  Alt 15. Jun 2010, 14:46
versuch es mal so:
Code:
SELECT EinIntegerFeld as test, EinIntegerFeld * 5 as Test2 FROM Tabellenname
Danke für die schnelle Antwort, EarlyBird.
Das klappt natürlich, aber das ist nicht das, was ich will.
In Wirklichkeit ist wie immer ein wenig komplizierter. Das, was in test drinsteht, wird durch eine sehr umfangreiche case when Struktur innerhalb des vorangehenden SQL Statements errechnet. Sinn der Angelegenheit ist, dass ich es mir spare, diese case when Struktur 10 mal im Code zu wiederholen.

Gibt's noch andere Ideen?
A fool with a tool remains a fool.
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

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

AW: Weiterverwenden eines erechneten Feldes

  Alt 15. Jun 2010, 14:50
Dann verwende eine Derived Table:
SQL-Code:
select
    test, test * 5 as Test2
from
    ( SELECT EinIntegerFeld as test FROM Tabellenname );
Markus Kinzler
  Mit Zitat antworten Zitat
EarlyBird

Registriert seit: 29. Mär 2007
235 Beiträge
 
#5

AW: Weiterverwenden eines erechneten Feldes

  Alt 15. Jun 2010, 15:03
Du könntest Dir eine Skalarwertfunktion schreiben und in der Abfrage nutzen.
Oder Du erstellst Dir eine gespeicherte Prozedur, dort deklarierst Du eine Variable der Du den berechneten Wert zuweist. Die Variable kannst Du dann im Selectstatemant weiterverwenden
  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 06:17 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