Top-Themen

AppleEntwicklungHardwareInternetLinuxMicrosoftMultimediaNetzwerkeOff TopicSicherheitSonstige SystemeVirtualisierungWeiterbildungZusammenarbeit

Aktuelle Themen

Administrator.de FeedbackApache ServerAppleAssemblerAudioAusbildungAuslandBackupBasicBatch & ShellBenchmarksBibliotheken & ToolkitsBlogsCloud-DiensteClusterCMSCPU, RAM, MainboardsCSSC und C++DatenbankenDatenschutzDebianDigitiales FernsehenDNSDrucker und ScannerDSL, VDSLE-BooksE-BusinessE-MailEntwicklungErkennung und -AbwehrExchange ServerFestplatten, SSD, RaidFirewallFlatratesGoogle AndroidGrafikGrafikkarten & MonitoreGroupwareHardwareHosting & HousingHTMLHumor (lol)Hyper-VIconsIDE & EditorenInformationsdiensteInstallationInstant MessagingInternetInternet DomäneniOSISDN & AnaloganschlüsseiTunesJavaJavaScriptKiXtartKVMLAN, WAN, WirelessLinuxLinux DesktopLinux NetzwerkLinux ToolsLinux UserverwaltungLizenzierungMac OS XMicrosoftMicrosoft OfficeMikroTik RouterOSMonitoringMultimediaMultimedia & ZubehörNetzwerkeNetzwerkgrundlagenNetzwerkmanagementNetzwerkprotokolleNotebook & ZubehörNovell NetwareOff TopicOpenOffice, LibreOfficeOutlook & MailPapierkorbPascal und DelphiPeripheriegerätePerlPHPPythonRechtliche FragenRedHat, CentOS, FedoraRouter & RoutingSambaSAN, NAS, DASSchriftartenSchulung & TrainingSEOServerServer-HardwareSicherheitSicherheits-ToolsSicherheitsgrundlagenSolarisSonstige SystemeSoziale NetzwerkeSpeicherkartenStudentenjobs & PraktikumSuche ProjektpartnerSuseSwitche und HubsTipps & TricksTK-Netze & GeräteUbuntuUMTS, EDGE & GPRSUtilitiesVB for ApplicationsVerschlüsselung & ZertifikateVideo & StreamingViren und TrojanerVirtualisierungVisual StudioVmwareVoice over IPWebbrowserWebentwicklungWeiterbildungWindows 7Windows 8Windows 10Windows InstallationWindows MobileWindows NetzwerkWindows ServerWindows SystemdateienWindows ToolsWindows UpdateWindows UserverwaltungWindows VistaWindows XPXenserverXMLZusammenarbeit

SQL-Abfrage: Ergebnis in Abhängigkeit eines anderen Feldes verändern

Frage Entwicklung Datenbanken

Mitglied: fischer-andreas

fischer-andreas (Level 1) - Jetzt verbinden

05.02.2007, aktualisiert 17:48 Uhr, 7424 Aufrufe, 2 Kommentare

SQL-Abfrage mit IIF, um Werte zu beeinflussen

Hallo!
Bin nicht allzu fit in MS SQL, aber brauche eine Lösung für folgendes Problem:
Ich habe einen SQL-Server, in dem ich im Query-Analyzer folgende Abfrage eingegeben habe:



SELECT KOSTKKA.KKa_Nr AS KA, KOSTKKA.KKa_Bez AS KABEZ, right(KOSTKKS.KKs_Nr,4) AS KST, KOSTKKS.KKs_Bez AS KSTBEZ, MONTH(KOSTKBU.KBu_BelDat)
AS Monat, YEAR(KOSTKBU.KBu_BelDat) AS Jahr, KOSTKBU.KBu_BelDat AS BelDat, KOSTKBU.KBu_Text AS BuchTXT,
KOSTKBU.KBu_Euro AS Betrag, KOSTKBU.KBU_Haben as Vorzeichen,
-----------> hier beginnt das Problem
iif(KOSTKBU.KBU_Haben = "-1", (KOSTKBU.KBU_Euro * (-1)) , KOSTKBU.KBU_Euro) AS TEST
-----------> und hier endet es.

FROM KOSTKBU INNER JOIN
KOSTKKS ON KOSTKBU.KKs_IdSoll = KOSTKKS.KKs_Id INNER JOIN
KOSTKKA ON KOSTKBU.KKa_IdSoll = KOSTKKA.KKa_Id
WHERE (KOSTKBU.KBu_MitarbV = 586)


Soweit alles gut, aber das Problem ist das iif......
Ich brauche den Wert von KBU_Euro, der je nachdem, welchen Wert KBU_Haben hat, entweder positiv oder negativ ist. KBU_Haben kann 0 oder -1 sein, d.h. wenn KBU_Haben 0 ist, dann soll KBU_Euro (150,00) z.B. -150,00 Euro sein. (*-1)

Ich weiß erstens schon nicht, ob so etwas innerhalb eines SELECT erlaubt ist und zweitens meckert der Analyzer die Syntax an:
Falsche Syntax in der Nähe von '='.
Habe schon ohne Anführungszeichen versucht, alles mögliche in Klammern usw. Komme einfach nicht drauf.

Daraus soll später ein DTS-Paket werden, dass die Werte automatisch in eine TXT-Datei konvertiert. Das funktioniert allerdings schon, jedoch ohne den iif-Teil.

Hat hier jemand eine Idee bzw. Hilfe? Danke im Voraus!

Andreas
Mitglied: AndreasHoster
05.02.2007 um 17:29 Uhr
IIF gibt es auf dem SQL Server nicht, in Access ja, aber nicht auf dem SQL Server (zumindestens bei SQL 2000).
Aber für die Aufgabe braucht man auch kein IIF.
Da sollte ein einfaches
(KOSTKBU.KBU_Haben + 0,5)*2*KOSTKBU.KBU_Euro as Test
ausreichen.
Bitte warten ..
Mitglied: Biber
05.02.2007 um 17:48 Uhr
*lach*
@AndreasHoster

Deine Variante ist aber gefährlich genial... die musst Du ja schon als Autor dreimal lesen, um sie zu verstehen.
Und da die Hinterlegbarkeit von Kommentarzeilen in SQL-Statements auch unter 64-Bit-Systemen immer noch ein wenig zu wünschen übrig lässt, hat in drei Wochen niemand mehr den Mut, an diesem Statement etwas zu ändern ("...da fass ich nichts an.. ich weiss nicht so genau, was da passiert...") .... trotzdem ein klares *ThumpsUp* von mir ...

@andreasfischer
Wenn Du etwas weniger prickelnd implementieren willst:
Das Äquivalent zu der merkwürdigen IIF(..)-Anweisung im noch merkwürdigeren Access ist:
01.
.... 
02.
Case  
03.
   When <bedingung> Then 'bla' 
04.
   Else 'blubb' 
05.
End 
06.
... 
07.
--oder in einem Fall: 
08.
.... 
09.
 feldx, 
10.
11.
 Case 
12.
   When KOSTKBU.KBU_Haben = -1 then KOSTKBU.KBU_Euro * (-1)  
13.
   Else KOSTKBU.KBU_Euro 
14.
End 
15.
) As test, 
16.
 feldy, 
17.
.....
P.S. Die Klammern rund um das "Case...End" sind eher dekorativ/zur Lesbarkeit....aber nicht nötig.
Und das Feld KOSTKBU.KBU_Haben habe ich wie auch Andreas als Numerisch unterstellt, nicht als CHAR.
P.P.S. Wo habt ihr denn die Tabellen- und Feldnamen gekauft? Bei einer Tiroler Jodelschule?

Gruss
Biber
Bitte warten ..
Neuester Wissensbeitrag
Windows 10

Powershell 5 BSOD

(8)

Tipp von agowa338 zum Thema Windows 10 ...

Ähnliche Inhalte
Datenbanken
gelöst SQL-Abfrage - DISTINCT - letztes Datum (3)

Frage von emeriks zum Thema Datenbanken ...

Datenbanken
SUM oder AVG in SQL Abfrage dauert viel zu lange warum? (5)

Frage von samet22 zum Thema Datenbanken ...

Datenbanken
gelöst SQL-Abfrage mit MAX() (9)

Frage von FrAmEr zum Thema Datenbanken ...

Heiß diskutierte Inhalte
Microsoft
Ordner mit LW-Buchstaben versehen und benennen (21)

Frage von Xaero1982 zum Thema Microsoft ...

Netzwerkmanagement
gelöst Anregungen, kleiner Betrieb, IT-Umgebung (18)

Frage von Unwichtig zum Thema Netzwerkmanagement ...

Windows Update
Treiberinstallation durch Windows Update läßt sich nicht verhindern (17)

Frage von liquidbase zum Thema Windows Update ...

Windows Tools
gelöst Aussendienst Datensynchronisierung (12)

Frage von lighningcrow zum Thema Windows Tools ...