[NEWSboard IBMi Forum]

Hybrid View

  1. #1
    Registriert seit
    Feb 2001
    Beiträge
    20.696
    Und hinter dem letzten "AUF" ist das Komma auch zu viel.
    Dienstleistungen? Die gibt es hier: http://www.fuerchau.de
    Das Excel-AddIn: https://www.ftsolutions.de/index.php/downloads
    BI? Da war doch noch was: http://www.ftsolutions.de

  2. #2
    Registriert seit
    Apr 2012
    Beiträge
    360
    Ich stehe da voll auf den Schlauch.

    Wo gebe ich die Datei an oder muss ich über das Statement noch was darüberlegen?

  3. #3
    Registriert seit
    Feb 2001
    Beiträge
    20.696
    Deine Datei wird immer nach dem From angegeben, so ist das bei SQL.
    Mittels "from (...) Name" kreirst du eine sog. "derived Table", also ein Zwischenergebnis.

    Innerhalb der Klammern kodierst du also einen ganz normalen Select mit Feldbenamung für berechnete Felder, so dass du im übergeordneten Select diese Felder verwenden kannst.

    select f1, f2, ...
    from (
    select aa as f1, bb as f2 ...
    from MyTable
    ) NewName

    jetzt kommt es noch darauf an, was du mit dem ganzen machen willst.
    Einfacher ist es wirklich ohne derived Table, wenn die Felder nur 1 Mal benötig werden:

    select sum( STD * (STS - STS / 100.00 * RAB + AUF / 100.00 * AUF) )
    from MyFile

    Je nachdem wie dein Rabatt oder Aufschlag wirken soll, musst du halt deine Klammern setzen. Einen Case sehe ich da i.M. gar nicht.
    Dienstleistungen? Die gibt es hier: http://www.fuerchau.de
    Das Excel-AddIn: https://www.ftsolutions.de/index.php/downloads
    BI? Da war doch noch was: http://www.ftsolutions.de

  4. #4
    Registriert seit
    Apr 2012
    Beiträge
    360
    Hat toll geklappt.

    Eine letzte Frage noch für Heute :

    Wieso bekomme ich bei diesem Statement eigentlich 4 Nachkommastellen angezeigt, obwohl ich alles mit 7, 2 angegeben habe?
    Code:
    SELECT Sum(STD * (STS - decimal(STS / 100.00 * RAB, 7,
    2) + decimal(STS / 100.00 * AUF, 7, 2) )) FROM FILE
    Gruß


    Tarki

  5. #5
    Registriert seit
    Feb 2001
    Beiträge
    20.696
    Du castest ja nur die Zwischenergebnisse und nicht das Endergebnis.
    Lass die Zwischencasts mal weg und caste das Endergebnis:

    decimal(sum ....., 11, 2)

    Berücksichtige dazu das max. mögliche Ergebnis um einen Überlauf auszuschließen.
    Dazu kommt noch, wie deine sonstigen Programme noch runden, also auf welchem Zwischenergebnis.
    Gerade bei Prozenten kann das nicht so unerheblich werden.

    SQL stellt dir die Funktion ROUND(Wert, Stellen) zur Verfügung.
    Dann kannst du das casten ganz sein lassen, da dies nur zum Abschneiden des Wertes führt, Beispiel:

    round(STS / 100.00 * RAB, 2)

    sum(round(....., 2))

    round(sum(....), 2)

    Je nach Ziel des Ergebnisses.
    Dienstleistungen? Die gibt es hier: http://www.fuerchau.de
    Das Excel-AddIn: https://www.ftsolutions.de/index.php/downloads
    BI? Da war doch noch was: http://www.ftsolutions.de

  6. #6
    Registriert seit
    Apr 2012
    Beiträge
    360
    Zitat Zitat von Fuerchau Beitrag anzeigen
    Du castest ja nur die Zwischenergebnisse und nicht das Endergebnis.
    Lass die Zwischencasts mal weg und caste das Endergebnis:

    decimal(sum ....., 11, 2)

    Berücksichtige dazu das max. mögliche Ergebnis um einen Überlauf auszuschließen.
    Dazu kommt noch, wie deine sonstigen Programme noch runden, also auf welchem Zwischenergebnis.
    Gerade bei Prozenten kann das nicht so unerheblich werden.

    SQL stellt dir die Funktion ROUND(Wert, Stellen) zur Verfügung.
    Dann kannst du das casten ganz sein lassen, da dies nur zum Abschneiden des Wertes führt, Beispiel:

    round(STS / 100.00 * RAB, 2)

    sum(round(....., 2))

    round(sum(....), 2)

    Je nach Ziel des Ergebnisses.
    Habe mich für die Varaiante decimal(sum ....., 11, 2) entschieden.

    Das mit round(sum(....), 2) hat auf Anhieb nicht geklappt, aber das probiere ich später noch aus.

    Gruß und Dank

    Tarki

  7. #7
    Registriert seit
    Feb 2001
    Beiträge
    20.696
    die Funktion Round steht dir dann ggf. noch nicht zur Verfügung.
    Ich glaube, die gibts erst ab V5R4.

    Solange du keine negativen Werte erzielst reicht dir ja erst mal ein

    decimal(sum(....) + 0.005, 11, 2)

    Dienstleistungen? Die gibt es hier: http://www.fuerchau.de
    Das Excel-AddIn: https://www.ftsolutions.de/index.php/downloads
    BI? Da war doch noch was: http://www.ftsolutions.de

Similar Threads

  1. RPGLE - SQL
    By christian_lettner in forum NEWSboard Programmierung
    Antworten: 2
    Letzter Beitrag: 16-11-06, 10:15
  2. SQL - Cursor vernichten ?!?
    By FNeurieser in forum NEWSboard Programmierung
    Antworten: 3
    Letzter Beitrag: 11-10-06, 14:53
  3. SQL und OBJLCK
    By malzusrex in forum IBM i Hauptforum
    Antworten: 8
    Letzter Beitrag: 19-09-06, 11:04
  4. SQL - Fehler
    By Kaufmann in forum IBM i Hauptforum
    Antworten: 11
    Letzter Beitrag: 28-06-06, 14:11
  5. SQL .. for update of (RPG embedded SQL)
    By loeweadolf in forum NEWSboard Programmierung
    Antworten: 2
    Letzter Beitrag: 01-06-06, 09:43

Berechtigungen

  • Neue Themen erstellen: Nein
  • Themen beantworten: Nein
  • You may not post attachments
  • You may not edit your posts
  •