[NEWSboard IBMi Forum]
Seite 3 von 7 Erste ... 2 3 4 ... Letzte
  1. #25
    Registriert seit
    Feb 2001
    Beiträge
    20.241
    Die F-Bestimmung lässt sich nicht variabel gestalten, da der Compiler die richtigen Befehle generieren muss.

    Gerade dafür ist ja der OVRDBF konzipiert um die F-Bestimmungen variabel zu nutzen.
    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. #26
    Registriert seit
    Feb 2001
    Beiträge
    20.241
    Die Anzahl der Member kann über CHGPF ... MAXMBR festgelegt werden.

    Ansonsten:
    PF-DTA ist eine PF die per CRTPF angelegt wurde.
    PF-SRC ist eine PF die mittels CRTSRCPF angelegt wurde.

    Bei DSPFD tauchen beide als PF auf.
    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. #27
    Registriert seit
    Sep 2006
    Beiträge
    132
    Danke.

    Aber wie müsste die F Bestimmung nach dem OVRDBF dann genau aussehen? Weil den Namen der Datei habe ich ja beim compilieren noch nciht.

  4. #28
    Registriert seit
    Dec 2002
    Beiträge
    301
    Das Ganze kann man auch ohne CL-Befehle (OVRDBF) variabel gestalten. Hier ein Beispiel.

    PHP-Code:
    fQDDSSRC   O    F   92        Disk    UsrOpn                                                    
    f                                     ExtFile
    (MyFile)                                           
    f                                     ExtMbr(MyMbr)                                             
     *                                                                                              
    dQDDSSRCRF        DS            92                                                              
    d SRCSEQ                         6A                                                             
    d SRCDAT                         6A                                                             
    d SRCDTA                        80A                                                             
     
    *                                                                                              
    dMyFile           S             21A                                                             
    dMyMbr            S             10A                                                             
     
    *                                                                                              
    c                   Eval      MyFile 'LIB/FILE'                          oder MyFile 'FILE' 
    c                   Eval      MyMbr 'MBR'                                                     
    c                   Open      QDDSSRC                                                           
    c                   Write     QDDSSRC       QDDSSRCRF                                           
    c                   Close     QDDSSRC 
    Frank Hildebrandt

  5. #29
    Registriert seit
    Sep 2006
    Beiträge
    132
    Zitat Zitat von Frank Hildebrandt
    Das Ganze kann man auch ohne CL-Befehle (OVRDBF) variabel gestalten. Hier ein Beispiel.

    PHP-Code:
    fQDDSSRC   O    F   92        Disk    UsrOpn                                                    
    f                                     ExtFile
    (MyFile)                                           
    f                                     ExtMbr(MyMbr)                                             
     *                                                                                              
    dQDDSSRCRF        DS            92                                                              
    d SRCSEQ                         6A                                                             
    d SRCDAT                         6A                                                             
    d SRCDTA                        80A                                                             
     
    *                                                                                              
    dMyFile           S             21A                                                             
    dMyMbr            S             10A                                                             
     
    *                                                                                              
    c                   Eval      MyFile 'LIB/FILE'                          oder MyFile 'FILE' 
    c                   Eval      MyMbr 'MBR'                                                     
    c                   Open      QDDSSRC                                                           
    c                   Write     QDDSSRC       QDDSSRCRF                                           
    c                   Close     QDDSSRC 
    Ah vielen Dank für das Beispiel.

  6. #30
    Registriert seit
    Aug 2001
    Beiträge
    2.873
    Hat sich erledigt! Frank war schneller!

    Birgitta
    Birgitta Hauser

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

  7. #31
    Registriert seit
    Sep 2006
    Beiträge
    132
    Zitat Zitat von B.Hauser
    Das ist so nicht korrekt!
    Solange der Aufbau der verwendeten Dateien bzw. Teil-Dateien identisch ist, kann die Datei variabel gestaltet werden. (Das ist bei sicher Quellen-(Teil-)Dateien der Fall!)
    Dazu werden die Schlüssel-Worte EXTFILE und EXTMBR verwendet. In diesen Schlüssel-Worten können die verwendete Datei (sogar qualifiziert mit Bibliothek), sowie die Teil-Datei als Variable hinterlegt werden. Voraussetzung ist allerdings, dass die Datei user controlled geöffnet wird und zwar erst dann, wenn die Variablen entsprechend gefüllt sind.

    Damit kann man sich den Override im CL sparen und bekommt auch keine Probleme, sollte man vergessen den OVRSCOPE zu ändern und unterschiedliche Aktivierungs-Gruppen verwenden.

    Zur Umwandlungszeit muss eine Datei mit dem in dem F-Bestimmungen angegeben Namen und dem erwarteten Aufbau existieren.

    Birgitta
    Also müsste ich nur während der Umwandlung eine Datei die so heißt erstellen und könnte sie nach der Kompilierung wieder löschen?

    Hm aber warum braucht die Datei einen erwarteten Aufbau wenn es doch eine DDS Datei ist/sein soll. Ich will ja sozusagen ein PF erstellen. (dh SCRDTA = " A fldnam 10A text('testbalbla')" )

    Tut mir Leid sollte ich mich oben falsch ausgedrückt habe. Bin heut irgendwie nicht gut drauf.(Kopfschmerzen & Co)

  8. #32
    Registriert seit
    Feb 2001
    Beiträge
    20.241
    Da gibts wohl ein bisschen Begriffsverwirrung:

    In einer Source-Datei legt man die Quellbestimmungen ab.
    Bei einem CRTPF gibt man diese Sourcedatei wiederum als Quelle mit den Erstellangaben an.

    Also:
    Du musst deine A-Bestimmungen in eine PF-SRC schreiben um anschliessend mittels CRTPF-Kommando eine DDS-beschriebene Datei erstellen zu können.
    Einen direkten Weg gibt es sonst nicht.

    Die Alternative ist dann eher SQL, da beim CREATE TABLE der Satzaufbau direkt mitgegeben wird, eine DDS-Quelle also nicht erforderlich ist.
    Trotzdem kann eine TABLE-Datei wie eine DDS-beschriebene Datei verwendet werden.

    Was deine Umwandlung angeht, so kannst du doch deine CLP-Quelle (QCLPSRC) z.B. als F-Bestimmung angeben.
    Ein Löschen der PF-SRC ist nicht erforderlich oder sinnvoll, da du diese sonst vor jeder Umwandlung wieder neu erstellen musst.
    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

  9. #33
    Registriert seit
    Sep 2006
    Beiträge
    132
    Zitat Zitat von Fuerchau
    Da gibts wohl ein bisschen Begriffsverwirrung:

    In einer Source-Datei legt man die Quellbestimmungen ab.
    Bei einem CRTPF gibt man diese Sourcedatei wiederum als Quelle mit den Erstellangaben an.

    Also:
    Du musst deine A-Bestimmungen in eine PF-SRC schreiben um anschliessend mittels CRTPF-Kommando eine DDS-beschriebene Datei erstellen zu können.
    Einen direkten Weg gibt es sonst nicht.

    Die Alternative ist dann eher SQL, da beim CREATE TABLE der Satzaufbau direkt mitgegeben wird, eine DDS-Quelle also nicht erforderlich ist.
    Trotzdem kann eine TABLE-Datei wie eine DDS-beschriebene Datei verwendet werden.

    Was deine Umwandlung angeht, so kannst du doch deine CLP-Quelle (QCLPSRC) z.B. als F-Bestimmung angeben.
    Ein Löschen der PF-SRC ist nicht erforderlich oder sinnvoll, da du diese sonst vor jeder Umwandlung wieder neu erstellen musst.
    Wieder vielen Dank für die freundlich Hilfe.
    Nochmal konkret zusammengefasst:

    1. Über mein CL Programm mithilfe von crtsrcpf eine Source Datei anlegen.
    2. RPG Programm aufrufen und damit die Beschreibungen in die Datei zu schreiben.(F Bestimmung wie oben gesagt?)
    3. Zurück im CL Programm das pf-src zu einer pf-dta umwandeln.

    Stimmt das dann so?

    Gruß

    Martin

  10. #34
    Registriert seit
    Sep 2006
    Beiträge
    132
    Noch eine Frage.
    Muss ich beim Übergeben von Parametern von CL zu RPG irgendetwas beachten?

    Bekomme gerade diesen Fehler:

    PHP-Code:
    *RNF3776 10 a      001200  Externes Programm im Prototyp für Hauptprozedur ist nicht identisch mit dem Programmdas erstellt wird
    Das ist mein Call:
    PHP-Code:
                CALL       PGM(DDSWRITEPARM('DDS' 'DDS'
    und das mein auffangen der Übergabe.
    PHP-Code:
    Daufnehm          PR                  EXTPGM('DDSTEST')
    D field1                        21A                    
    D field2                        10A                    
                                                           
    Daufnehm          PI                                   
    D MyFile                        21A                    
    D MyMbr                         10A 
    EDIT: Problem behoben.
    Es gitb jedoch noch Fehler beim Open...

  11. #35
    Registriert seit
    Sep 2006
    Beiträge
    132
    Hallo habe noch ein Problem und zwar lässt sich die neu erstellte Datei "DDS" nicht öffnen.

    PHP-Code:
    FDDS       O    F   92        Disk    UsrOpn         
    f                                     ExtFile
    (MyFile)
    f                                     ExtMbr(MyMbr)  
                                                         
    DCMDREC           DS            92                             
    DSRCSEQ                          6S 2                          
    DSRCDAT                          6S 0                          
    DSRCDTA                         80A                            
                                                                   
    C
    *     *entry        plist                                      
    C
    *                   parm                    MyFile           21
    C
    *                   parm                    MyMbr            10
    C                   
    eval      MyFile 'LIB/DDS'        
    C                   eval      MyMbr 'DDS'                
    C                                                          
    C                   
    eval      srcseq 0001.00             
    C                   
    eval      srcdat 0609121             
    C                   
    eval      srcdta 'dies ist ein test' 
    C                   open(e)   dds                          
    C
    *                  IF        not %ERROR                   
    C                   write     dds           cmdrec         
    C
    *                  endif                                  
    C                   close     dds                          
    C                   
    return 
    Hat jmd eine Idee warum bzw wie ich herausfinden kann warum? Die Fehlermeldung sagt nur das Write fehlschlägt weil die Datei geschlossen ist.

  12. #36
    Registriert seit
    Feb 2001
    Beiträge
    20.241
    Schau mal ins Joblog, lass mal das "(e)" beim Open weg.
    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. ILE RPG / SQL Füllen einer Feldgruppe
    By homue in forum NEWSboard Programmierung
    Antworten: 5
    Letzter Beitrag: 18-07-07, 16:47
  2. Problem mit Java-Methoden Aufruf aus ILE RPG?
    By Stoeberl in forum NEWSboard Programmierung
    Antworten: 8
    Letzter Beitrag: 10-01-07, 10:58
  3. ILE RPG und dynamisches Array
    By Squall in forum NEWSboard Programmierung
    Antworten: 9
    Letzter Beitrag: 10-10-06, 08:53
  4. Return ILE RPG
    By Squall in forum IBM i Hauptforum
    Antworten: 31
    Letzter Beitrag: 28-09-06, 17:53
  5. Rechnen mit Datumsfeldern in ILE RPG
    By Angela in forum IBM i Hauptforum
    Antworten: 4
    Letzter Beitrag: 22-08-06, 10:11

Berechtigungen

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