You are currently browsing the tag archive for the ‘AS400’ tag.


 d up              C                   'ABCDEFGHIJKLMNOPQRSTUVWXYZ'
 d lo              C                   'abcdefghijklmnopqrstuvwxyz'
 d case            S            100A
 c     *entry        plist
 c                   parm                    case
 /FREE
       case = %xlate(lo:up:case);
 /END-FREE
 
Advertisements

tanpa JDFTVAL maka join tersebut adalah inner join. artinya record yang ditampilakan adalah record yang value dari join field harus match di kedua file tsb
dengan JDFTVAL maka join tersebut adalah outer (Left) Join. artinya record yang ditampilkan adalah seluruh record dari PF1, dan field dari PF2 yang berkorespondensi dengan PF1. jika di PF2 tidak ada, maka terisi blank.

PF1 :

A          R PF1PR            
A            NAMA          10A
A            ALAMAT        10A
A            TLP           12A
A          K NAMA

PF2 :

A          R PF2PR            
A            NAMA          10A
A            STATUS         1A
A            ANAK           2A
A          K NAMA

Join1:

A                                      JDFTVAL        
A          R LFJOINR                   JFILE(PF1 PF2) 
A                                                     
A          J                           JOIN(1 2)      
A                                      JFLD(NAMA NAMA)
A*                                                    
A            NAMA                      JREF(1)        
A            ALAMAT                    JREF(1)        
A            TLP                       JREF(1)        
A            STATUS                    JREF(2)        
A            ANAK                      JREF(2)

       
Join2:

A          R LFJOINR                   JFILE(PF1 PF2) 
A                                                     
A          J                           JOIN(1 2)      
A                                      JFLD(NAMA NAMA)
A*                                                    
A            NAMA                      JREF(1)        
A            ALAMAT                    JREF(1)        
A            TLP                       JREF(1)        
A            STATUS                    JREF(2)        
A            ANAK                      JREF(2)

note: key (K) tidak mempengaruihi isi join yang akan ditampilkan. K hanya sebagai indexing atau key chain.

Banyak metode yang dapat digunakan untuk mengambil source code dari AS/400 ke PC. Saya lebih sering menggunakan FTP, karena lebih mudah dapat dibaca di PC berupa text file. Kali ini akan saya coba ulas sedikit cara mengambil source code dari AS/400 ke PC (Os. Windows).

Asumsi bahwa source code yang akan diambil berada di :

AS/400 dengan IP : 10.10.1.10
Library : Eden
Source File : QRPGLESRC
Member : TST1R

Cara simple untuk mengambil code tersebut adalah menggunakan commad prompt yang tersedia di Windows. Berikut langkah-langkahnya

1. Nyalakan aplikasi command prompt. Secara default apliasi ini ada di “Program Files” -> “Accesories” -> “Command Prompt”. Tips : tekan Win+R, kemudian ketikan “cmd” (tanpa tanda kutip) dan Enter.

2. Tuju ke folder yang akan dijadikan tempat untuk menyimpan source code yang akan diambil. Misalkan saya akan menyimpan di Drive D, maka commandnya adalah “D:”.

3. Akses server AS/400 menggunakan FTP. Ketikan command FTP ip-Address, dalam hal ini : “FTP 10.10.1.10” (tanpa tanda kutip). Kemudian Log-in.

4. Set library source code sebagai current library. Gunakan command “CD nama-library”, dalam hal ini : “CD Eden” (tanpa tanda kutip).

6. Ambil source code. Gunakan command “Get nama-source-file.nama-member”, dalam hal ini : “Get QRPGLESRC.TST1R” (tanpa tanda kutip).

7. Maka source code akan ada di dirve D dengan nama file : Qrpglesrc.Tst1R. Source code ini berupa text file, bisa dibuka di notepad atau text editor lainnya.

8. Untuk keluar dari FTP dan Command Prompt, ketikan command bye – enter – exit – enter.

Kurang lebih jika step-step ini dijalankan yang muncul di layar command prompt akan seperti ini :

Microsoft Windows XP [Version 5.1.2600]
(C) Copyright 1985-2001 Microsoft Corp.
C:\Documents and Settings>d:
D:\>FTP 10.10.1.10
Connected to 10.10.1.10.
220-QTCP at AS400.
220 Connection will close if idle more than 5 minutes.
User (10.10.1.10:(none)): eden
331 Enter password.
Password:
230 EDEN logged on.
ftp> cd eden
250 "EDEN" is current library.
ftp> get qrpglesrc.tst1r
200 PORT subcommand request successful.
150 Retrieving member TST1R in file QRPGLESRC in library EDEN.
250 File transfer completed successfully.
ftp: 633 bytes received in 0.09Seconds 6.73Kbytes/sec.
ftp> bye
221 QUIT subcommand received.
D:\> exit

Untuk selanjutnya, dengan beberapa modifikasi, cara ini saya gunakan sebagai salah satu cara dalam mem-backup source code AS/400.

Bagi para pecinta indicator, mungkin ini sedikit tips untuk mempermudah membaca code dikemudian hari.

Buat variable found/not found :

D Found           S              1A   INZ('0')
D NotFound        S              1A   INZ('1')

Kemudian di kodingan bisa seperti ini :

c     DISKEY        chain     T1KEN10LR                          96
c                   if        *in96 = NotFound

atau

c     DISKEY        chain     T1AGUNAR                           98
c                   if        *in98 = NotFound or
c                             (*in98 = Found and aStaval = 'S')

Toh ini akan sama aja dengan :

c     DISKEY        chain     T1KEN10LR                          96
c                   if        *in96 = '1'

atau

c     DISKEY        chain     T1AGUNAR                           98
c                   if        *in98 = '1' or
c                             (*in98 = '0' and aStaval = 'S')

Cuma perlu diingat, untuk command LOOKUP found itu bernilai ‘1’ dan not found bernilai ‘0’ (kebalikan dari chain/reade)

 

*Nb. Tips ini didapat dari mas Prayugo ketika diskusi optimalisasi JF.

Akhirnya ada juga tentang AS400 yang bisa saya share disini, sekalian reminder juga buat sendiri… :p

klo perlu read table (PF) tapi pengen di CL kita bisa pake command RCVF (Receive File). Nah, nama file yang akan dibuka di declare dulu pake DCLF (Declare File) dibagian declare variabel. CPF0864 (End of file detected for file) bisa digunakan untuk nge-cek apakah record found or not found.

Contoh code :

* PF (SPOOL1P) :
A          R SPOOLR
A            SPOOL 133A

/*CL :*/
PGM

DCL  VAR(&STSJOB) TYPE(*CHAR) LEN(4)
DCLF FILE(SPOOL1P)

RCVF   RCDFMT(SPOOLR)
MONMSG MSGID(CPF0864) EXEC(GOTO CMDLBL(EXIT))
CHGVAR VAR(&STSJOB) VALUE(%SST(&SPOOL 111 4))

EXIT:
ENDPGM

Command ini selanjutnya saya kembangkan untuk cek status job, apakah MSGW atau tidak. Untuk bagian ini…. insya Allah saya posting lagi nanti… 😉
Semoga bermanfaat…

thanks to Mr. Colin.W for the answer, it’s works 😀

Mr. Colin. W said :

“I usually get that message when I have not set a parameter in a calling
program, and im trying to use it in the called program,
or I am passing a field that is longer or shorter than the parameter field
that I have declared and so am messing up the parameters somehow”

and that’s true. I’ve got this error to (Pointer not set for location referenced), in my case it cause by the shorter parameter that i’m passing to another program. from CL program to another CL program and from CL program to RPGLE program.

reminder again…. 😀

..::: cuplikan code supaya bisa pake CL command di RPGLE :::..

D*  ini bagian deklarasi dan inisialisasi
D CMDX            S            500    INZ(*blank) VARYING
D CMDLINE         PR                  Extpgm(‘QCMDEXC’)
D STRING                      1000    Const
D                                     Options(*Varsize)
D LEN                           15P 5 Const

C* ini bagian CL command yang dipanggilnya. exp : “RMVLNK”
/FREE
CMDX = ‘RMVLNK SFILNM’;
CALLP CMDLINE(CMDX:%LEN(CMDX));
/END-FREE
C*

*sory ga dirapihin… :p

dimanakah indikator dalam RPG diletakan ?

reade -> EQ        found -> ‘0’
read  -> EQ
readp -> EQ
chain -> HI        found -> ‘0’
update -> LO
write -> LO
delete -> LO
lookup -> EQ    found -> ‘1’