[NEWSboard IBMi Forum]

Thema: Sql Abfrage

Hybrid View

  1. #1
    Registriert seit
    Jan 2003
    Beiträge
    759
    <unschön>
    MOVEL JAHR4N DAT8N
    MOVE '0101' DAT8N
    </unschön>

    DAT8N = (JAHR4N*10000)+101;

  2. #2
    Registriert seit
    Feb 2001
    Beiträge
    20.696
    ILE:
    %int(Datum/10000) * 10000 + 0101;

    SQL:
    floor(Datum / 10000) * 10000 + 0101
    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

  3. #3
    Registriert seit
    Apr 2012
    Beiträge
    360
    Danke für eure Antworten und Hilfen.

    Gruß
    Tarki

  4. #4
    Registriert seit
    Apr 2012
    Beiträge
    360
    Hallo Herr Fuerchau,

    ich habe eine Datei, wo Abteilungen mit Datum, und Preisen hinterlegt sind.

    Wie erhalte ich eigentlich im Sql, nur einen Satz, der gerade aktuell ist, ohne das ich die anderen lesen müssen?

    Gruß

    Tarki

  5. #5
    Registriert seit
    Aug 2001
    Beiträge
    2.928
    Hast Du neben dem Datum und dem Preis auch noch andere Informationen z.B. Artikel-Nr. in der Datei?

    Sofern Du nur den Preis mit dem höchsten Datum willst, kannst Du diesen wie folgt ermitteln:

    Code:
    Select Datum, Preis
    From Datei
    Order By Datum Desc
    Fetch First Row Only
    Sofern Du zusätzlich z.B. auch noch die Artikel-Nr. hast und den Preis nur für einen bestimmten Artikel willst, kannst Du die gleiche Abfrage nehmen und fügst eine WHERE-Bedingung ein, mit der nur der entsprechende Artikel ausgewählt wird.

    Sofern Du den jeweils den aktuellen Preis von allen Artikeln willst wird die Sache etwas komplexer, d.h. Du brauchst entweder ein verschachteltes (Sub-)Select oder eine Common Table Expression, durch die zunächst das letzte Datum pro Artikel ermittelt wird. Das Ergebnis verknüpfst Du dann mit der eigentlichen Tabelle/Datei.

    Birgitta
    Birgitta Hauser

    Anwendungsmodernisierung, Beratung, Schulungen, Programmierung im Bereich RPG, SQL und Datenbank
    IBM Champion seit 2020 - 5. Jahr in Folge
    Birgitta Hauser - Modernization - Education - Consulting on IBM i

  6. #6
    Registriert seit
    Apr 2012
    Beiträge
    360
    Danke Frau Hauser,

    Goldrichtiges Statement.

    Gruß

    Tarki

  7. #7
    Registriert seit
    Feb 2001
    Beiträge
    20.696
    Empfehlenswert ist in diesem Fall auch ein Index mit "Datum desc".
    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

  8. #8
    Registriert seit
    Aug 2001
    Beiträge
    2.928
    Zitat Zitat von Fuerchau Beitrag anzeigen
    Empfehlenswert ist in diesem Fall auch ein Index mit "Datum desc".
    Zugriffsweg mit Datum reicht (zumindest wenn die Abfrage von der SQE ausgeführt wird). SQL verarbeitet auf- und absteigend.

    Birgitta
    Birgitta Hauser

    Anwendungsmodernisierung, Beratung, Schulungen, Programmierung im Bereich RPG, SQL und Datenbank
    IBM Champion seit 2020 - 5. Jahr in Folge
    Birgitta Hauser - Modernization - Education - Consulting on IBM i

Similar Threads

  1. Einfache Abfrage in COBOL/400 mit EXEC SQL
    By AS400-Anfänger in forum NEWSboard Programmierung
    Antworten: 6
    Letzter Beitrag: 27-06-06, 13:18
  2. Abfrage nach <> Ziffern in SQL
    By behmer in forum IBM i Hauptforum
    Antworten: 1
    Letzter Beitrag: 29-05-06, 12:52
  3. sql abfrage
    By steven_r in forum NEWSboard Programmierung
    Antworten: 3
    Letzter Beitrag: 17-05-06, 15:49
  4. Problem bei Abfrage bei Imbedded SQL
    By cbe in forum NEWSboard Programmierung
    Antworten: 2
    Letzter Beitrag: 08-06-05, 16:21
  5. sql abfrage mit substring
    By juergenkemeter in forum NEWSboard Programmierung
    Antworten: 5
    Letzter Beitrag: 17-11-04, 14:32

Berechtigungen

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