AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Delphi SQL Umsetzung für Firebird
Thema durchsuchen
Ansicht
Themen-Optionen

SQL Umsetzung für Firebird

Ein Thema von clock50 · begonnen am 9. Aug 2009 · letzter Beitrag vom 11. Aug 2009
Antwort Antwort
Seite 1 von 2  1 2      
clock50

Registriert seit: 9. Nov 2005
Ort: Derenburg
183 Beiträge
 
Delphi 5 Professional
 
#1

SQL Umsetzung für Firebird

  Alt 9. Aug 2009, 20:13
Datenbank: Firebird • Version: 1.5 • Zugriff über: IB
Hallo Leute,

ich bin gerade dabei eine DB von mySQL auf Firebird umzubauen.

Bei mySQL hat folgendes geplappt aber bei Firebird kennt es kein 'if' in der Abfrage

SQL-Code:
SELECT rechnung.RechNr AS RechNr, rechnung.Datum AS Datum, rechnung.ReBetrag AS ReBetrag,
Sum(IF ( daten.MwSt =7, daten.Anzahl * daten.ArtPreis * ( daten.MwSt /100 ) , 0 ) ) AS SumMwSt7,
Sum(IF ( daten.MwSt =19, daten.Anzahl * daten.ArtPreis * ( daten.MwSt /100 ) , 0 ) ) AS SumMwSt19
FROM rechnung JOIN daten ON daten.ReNr = rechnung.RechNr WHERE EXTRACT(MONTH FROM rechnung.Datum ) =
8 AND EXTRACT( YEAR FROM rechnung.Datum ) = 2009 GROUP BY rechnung.datum, rechnung.RechNr
Alles klappt bis auf Sum(IF ...
Thomas
Man muß nicht alles wissen, man muß nur wissen in welchem Buch es geschrieben steht!
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

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

Re: SQL Umsetzung für Firebird

  Alt 9. Aug 2009, 20:31
Firebird unterstützt die SQL-Standard Funktion IIF()
Markus Kinzler
  Mit Zitat antworten Zitat
clock50

Registriert seit: 9. Nov 2005
Ort: Derenburg
183 Beiträge
 
Delphi 5 Professional
 
#3

Re: SQL Umsetzung für Firebird

  Alt 10. Aug 2009, 10:33
Danke für die schnelle Antwort.

Jetzt kommt das:
Sum(IIF( RDATEN.MWST = 7, (Rdaten.Anz * Rdaten.Preis * (Rdaten.MwSt /100)) , 0 )) AS SumMwSt7 Token unknown line ..., char ...
=.

geht das überhaupt oder sollte ich besser
SQL-Code:

CASE
    WHEN RATEN.MWST = 7 THEN Sum(Rdaten.Anz * Rdaten.Preis * (Rdaten.MwSt /100)) as SumMwSt7
    WHEN RATEN.MWST = 19 THEN Sum(Rdaten.Anz * Rdaten.Preis * (Rdaten.MwSt /100)) as SumMwSt19
END
oder so schreiben
Thomas
Man muß nicht alles wissen, man muß nur wissen in welchem Buch es geschrieben steht!
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

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

Re: SQL Umsetzung für Firebird

  Alt 10. Aug 2009, 11:41
Man kann auch CASE..WHEN nehmen, aber der Fehler muss wo anders liegen.
Du verwendest zum Beispiel eine andere Tabelle als im unteren Beispiel
Markus Kinzler
  Mit Zitat antworten Zitat
clock50

Registriert seit: 9. Nov 2005
Ort: Derenburg
183 Beiträge
 
Delphi 5 Professional
 
#5

Re: SQL Umsetzung für Firebird

  Alt 10. Aug 2009, 21:45
Ja mit Raten habe ich mich verschieben aber bei Firebird heist meine Tabelle RDaten
Thomas
Man muß nicht alles wissen, man muß nur wissen in welchem Buch es geschrieben steht!
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

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

Re: SQL Umsetzung für Firebird

  Alt 11. Aug 2009, 05:38
Zeig mal das komplette Statement
Markus Kinzler
  Mit Zitat antworten Zitat
clock50

Registriert seit: 9. Nov 2005
Ort: Derenburg
183 Beiträge
 
Delphi 5 Professional
 
#7

Re: SQL Umsetzung für Firebird

  Alt 11. Aug 2009, 09:50
SQL-Code:
SELECT RECHNUNG.RNR AS RNR, RECHNUNG.DATUM AS DATUM, Sum(RDATEN.ANZ * RDATEN.PREIS) AS NSUMME,
Sum(RDATEN.ANZ * RDATEN.PREIS * (RDATEN.MWST/100)) AS BSUMME,
Sum( IIF(RDATEN.MWST = 7, RDATEN.ANZ * RDATEN.PREIS * (RDATEN.MWST/100), 0)) AS SumMwSt7,
Sum( IIF(RDATEN.MWST = 19, RDATEN.ANZ * RDATEN.PREIS * (RDATEN.MWST/100), 0)) AS SumMwSt19
FROM RECHNUNG
JOIN RDATEN ON RDATEN.RNR = RECHNUNG.RNR
WHERE EXTRACT(
MONTH FROM RECHNUNG.DATUM ) = 1 AND EXTRACT( YEAR
FROM RECHNUNG.DATUM ) =2009
GROUP BY RECHNUNG.DATUM, RECHNUNG.RNR;
Er mault bei Sum( IIF(RDATEN.MWST = 7, RDATEN.ANZ * RDATEN.PREIS * (RDATEN.MWST/100), 0)) AS SumMwSt7,
Thomas
Man muß nicht alles wissen, man muß nur wissen in welchem Buch es geschrieben steht!
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

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

Re: SQL Umsetzung für Firebird

  Alt 11. Aug 2009, 10:01
Zitat:
Er mault bei Sum( IIF(RDATEN.MWST = 7, RDATEN.ANZ * RDATEN.PREIS * (RDATEN.MWST/100), 0)) AS SumMwSt7,
Versuch es mal mit Tabellen-Aliasen, dann ist es etwas übersichtlicher. Zudem haben ein paar Klammern gefehlt
SQL-Code:
SELECT
    r.RNR AS RNR, r.DATUM AS DATUM,
    Sum( rd.ANZ * rd.PREIS) AS NSUMME,
    Sum( rd.ANZ * rd.PREIS * (rd.MWST/100)) AS BSUMME,
    Sum( IIF( rd.MWST = 7, rd.ANZ * rd.PREIS * ( rd.MWST/100), 0))) AS SumMwSt7,
    Sum( IIF( rd.MWST = 19, rd.ANZ * rd.PREIS * ( rd.MWST/100), 0))) AS SumMwSt19
FROM
    RECHNUNG r
        JOIN RDATEN ON RDATEN.RNR rd, = RECHNUNG.RNR
WHERE
    EXTRACT( MONTH FROM r.DATUM ) = 1 AND
    EXTRACT( YEAR FROM r.DATUM ) = 2009
GROUP BY
    r.DATUM, r.RNR;
Markus Kinzler
  Mit Zitat antworten Zitat
clock50

Registriert seit: 9. Nov 2005
Ort: Derenburg
183 Beiträge
 
Delphi 5 Professional
 
#9

Re: SQL Umsetzung für Firebird

  Alt 11. Aug 2009, 10:38
Es hängt an der selben Stelle, ich habe nochmal das Script für die DB angehängt der Fehler könnte auch da liegen.
Angehängte Dateien
Dateityp: txt neu_863.txt (4,5 KB, 6x aufgerufen)
Thomas
Man muß nicht alles wissen, man muß nur wissen in welchem Buch es geschrieben steht!
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

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

Re: SQL Umsetzung für Firebird

  Alt 11. Aug 2009, 10:43
Datum ist ja ein String Warum?
Markus Kinzler
  Mit Zitat antworten Zitat
Antwort Antwort
Seite 1 von 2  1 2      


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 17:07 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