[NEWSboard IBMi Forum]

Thema: QMHSNDPM

Hybrid View

  1. #1
    Registriert seit
    Apr 2012
    Beiträge
    360
    Hallo,

    ich hätte vor in ein Programm, das im Batch läuft, diverse Dateioperationen mittels Sql abzulösen.
    Im Programm wird ja bei einem Write, bei einem doppelten Schlüssel, eine Nachricht an den Sysopr geschickt.

    Ich hätte nun versucht beim Insert den Sqlstate abzufragen und mit Hilfe der API QMHSNDPM eine Msg zu schicken.

    Ich bekomme aber keine Nachricht auf den SYSOPR.

    Code:
    Der Aufruf an *LIBL/QMHSNDPM wurde fehlerhaft beendet (C G D F).       
    SBMJOB CMD(CALL PGM(EDAVJS235R) PARM('                 '))    
    
    
    DQMHSNDPM         PR                  ExtPgm('QMHSNDPM')           
    D MsgID                          7A   Const                        
    D MsgFile                       20A   Const                        
    D MsgData                      256A   Const                        
    D MsgDtaLen                     10I 0 Const                        
    D MsgType                       10A   Const                        
    D StackEntry                    10A   Const                        
    D StackCount                    10I 0 Const                        
    D MsgKey                         4A   Const                        
    D ErrorCode                     16A   Const                        
    D                                                                  
    D$MsgId           S             10A   Inz('CPF9898   ')            
    D$MsgFile         S             20A   Inz('QCPFMSG   QSYS      ')  
    D$MsgDta          S             80A   Inz                          
    D$MsgDtaLen       S             10I 0 Inz                          
    D                                                                  
    D ErrorCode       ds                                               
    D   BytesProv                   10I 0 inz(0)                       
    D   BytesAvail                  10I 0                              
    
    
    
    
    
    
    $MsgDta    = 'SQL ERROR: '                           
                + %trimr(SDSPGM)                         
                + ' Fehler beim Import aufgetreten';     
                                                         
    QMHSNDPM( $MsgId                                     
            : $MsgFile                                   
            : $MsgDta                                    
            : %len( %trimr($MsgDta))                     
            : '*ESCAPE'                                  
            : '*'                                        
            : 2                                          
            : *blanks                                    
            : ErrorCode );
    Das Programm hat einen *ENTRY Parameter.
    Was mache ich falsch?

    Kann ich eleganter eine exception auf den Sysopr werfen?

    Dank im Voraus

    Tarki

  2. #2
    Registriert seit
    Feb 2001
    Beiträge
    20.791
    Warum postest du deine Frage mehrfach?
    Der CALL-Stack "*" sendet eine Nachricht an dich selber.
    Du musst da als Ziel denn doch eine höhere Ebene angeben.
    Außerdem wird nicht automatisch auch an QSYSOPR gesendet, das macht ggf. das Empfänger-Programm mit einem SNDMSG (ggf. mit Antwort) statt SNDPGMMSG.

    Wenn ich im CLP einen MONMSG verwende, erwarte ich ja auch eine Abbruchnachricht an mein Programm und nicht erst an eine MSGQ. Dies ist dann eher unüblich.
    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
    Morgen,

    Verzeihung den doppelten Post, dachte mir beim Forum Programmierung trifft das eher zu.

    Danke für die Antwort.

Similar Threads

  1. Dateigröße ermitteln und anzeigen
    By Bratmaxxe in forum NEWSboard Programmierung
    Antworten: 9
    Letzter Beitrag: 08-01-07, 10:50
  2. CMD / CL / RTNVAL(*YES)
    By V_P in forum NEWSboard Programmierung
    Antworten: 7
    Letzter Beitrag: 14-11-06, 11:42
  3. sndpgmmsg als API
    By Robi in forum IBM i Hauptforum
    Antworten: 3
    Letzter Beitrag: 14-12-04, 11:01
  4. Trigger / ILE RPG
    By Frank Pusch in forum IBM i Hauptforum
    Antworten: 3
    Letzter Beitrag: 17-05-01, 10:34

Berechtigungen

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