Wednesday, August 9, 2017

H Spec in RPGLE


ACTGRP(*NEW | *CALLER | ’activation-group-name’) The ACTGRP keyword allows you to specify the activation group the program is associated with when it is called.

ALTSEQ{(*NONE | *SRC | *EXT)} The ALTSEQ keyword indicates whether an alternate collating sequence is used, if so, whether it is internal or external to the source.

ALWNULL(*NO | *INPUTONLY | *USRCTL) The ALWNULL keyword specifies how you will use records containing null-capable fields from externally described database files.

If ALWNULL(*NO) is specified, then you cannot process records with null-value fields from externally described files.

If ALWNULL(*INPUTONLY) is specified, then you can successfully read records with null-capable fields containing null values from externally described input-only database files.

If ALWNULL(*USRCTL) is specified, then you can read, write, and update records with null values from externally described database files.

AUT(*LIBRCRTAUT | *ALL | *CHANGE | *USE | *EXCLUDE | ’authorization-list-name’) The AUT keyword specifies the authority given to users who do not have specific authority to the object, who are not on the authorization list, and whose user group has no specific authority to the object. The authority can be altered for all users or for specified users after the object is created with the CL commands Grant Object Authority (GRTOBJAUT) or Revoke Object Authority (RVKOBJAUT).

BNDDIR(’binding-directory-name’ {:’binding-directory-name’...}) The BNDDIR keyword specifies the list of binding directories that are used in symbol resolution.


CCSID(*GRAPH : parameter | *UCS2 : number | *CHAR : *JOBRUN) CCSID(*GRAPH) and CCSID(*UCS2) set the default graphic (*GRAPH) and UCS-2 (*UCS2) CCSIDs for the module. These defaults are used for literals, compile-time data, program-described input and output fields, and data definitions that do not have the CCSID keyword coded.

COPYNEST(number) The COPYNEST keyword specifies the maximum depth to which nesting can occur for /COPY directives. The depth must be greater than or equal to 1 and less than or equal to 2048. The default depth is 32.

COPYRIGHT(’copyright string’) The COPYRIGHT keyword provides copyright information that can be seen using the DSPMOD, DSPPGM, or DSPSRVPGM commands.

CURSYM(’sym’) The CURSYM keyword specifies a character used as a currency symbol in editing. The symbol must be a single character enclosed in quotes.

CVTOPT(*{NO}DATETIME *{NO}GRAPHIC *{NO}VARCHAR *{NO}VARGRAPHIC) The CVTOPT keyword is used to determine how the ILE RPG compiler handles date, time, timestamp, graphic data types, and variable-length data types that are retrieved from externally described database files.

DATEDIT(fmt{separator}) The DATEDIT keyword specifies the format of numeric fields when using the Y edit code. The separator character is optional. The value (fmt) can be *DMY, *MDY, or *YMD. The default separator is /. A separator character of & (ampersand) may be used to specify a blank separator.


DATFMT(fmt{separator}) The DATFMT keyword specifies the internal date format for date literals and the default internal format for date fields within the program. You can specify a different internal date format for a particular field by specifying the format with the DATFMT keyword on the definition specification for that field.

DEBUG{(*NO | *YES)}

The DEBUG keyword determines

1) whether DUMP operations are performed

2) whether unused externally described input fields are moved from the buffer during input operations.

DUMP operations are performed if either DEBUG or DEBUG(*YES) is specified.

If DEBUG or DEBUG(*YES) is specified, all externally described input fields will be entered even if they are not used in the program.


DECEDIT(*JOBRUN | ’value’)

The DECEDIT keyword specifies the character used as the decimal point for edited decimal numbers and whether or not leading zeros are printed.


DECPREC(30|31|63)

Keyword DECPREC is used to specify the decimal precision of decimal (packed, zoned, or binary) intermediate values in arithmetic operations in expressions. Decimal intermediate values are always maintained in the proper precision, but this keyword affects how decimal expressions are presented when used in %EDITC, %EDITW, %CHAR, %LEN, and %DECPOS.


DFTACTGRP(*YES | *NO)


The DFTACTGRP keyword specifies the activation group in which the created program will run when it is called. If *YES is specified, then this program will always run in the default activation group, which is the activation group where all original program model (OPM) programs are run. This allows ILE RPG programs to behave like OPM RPG programs in the areas of file sharing, file scoping, RCLRSC, and handling of unmonitored exceptions. ILE static binding is not available when a program is created with DFTACTGRP(*YES). This means that you cannot use the BNDDIR or ACTGRP command parameters or keywords when creating this program. In addition, any call operation in your source must call a program and not a procedure. DFTACTGRP(*YES) is useful when attempting to move an application on a program-by-program basis to ILE RPG.


If *NO is specified, then the program is associated with the activation group specified by the ACTGRP command parameter or keyword and static binding is allowed. DFTACTGRP(*NO) is useful when you intend to take advantage of ILE concepts; for example, running in a named activation group or binding to a service program. If the DFTACTGRP keyword is not specified, then the value specified on the command is used. The DFTACTGRP keyword is valid only if the CRTBNDRPG command is used.

DFTNAME(rpg_name)

The DFTNAME keyword specifies a default program or module name. When *CTLSPEC is specified on the create command, the rpg_name is used as the program or module name. If rpg_name is not specified, then the default name is RPGPGM or RPGMOD for a program or module respectively.

ENBPFRCOL(*PEP | *ENTRYEXIT | *FULL)


The ENBPFRCOL keyword specifies whether performance collection is enabled. If *PEP is specified, then performance statistics are gathered on the entry and exit of the program-entry procedure only. This applies to the actual program-entry procedure for an object, not to the main procedure of the object within the object. If *ENTRYEXIT is specified, then performance statistics are gathered on the entry and exit of all procedures of the object. If *FULL is specified, then performance statistics are gathered on entry and exit of all procedures. Also, statistics are gathered before and after each call to an external procedure.

If the ENBPFRCOL keyword is not specified, then the value specified on the command is used.



Sharing Data Between Systems


Sometimes, the data we want is on a different System i platform. We could transfer the data using a number of different techniques, such as:

·         FTP

·         A combination of save and restore commands

·         Send Net Object (SNDNETOBJ)

However, these techniques physically move the data, creating copies of the same information on the different systems. And we all know what happens next - the information becomes "out of sync" as updates are made to the data on one system and not on the other.

Here's a technique that can be used to share low-level amounts of data. The data will reside on one system, but it can be accessed by both that system and other systems. All it takes is a little configuration and Distributed Data Management (DDM).

DDM is a protocol that enables SNA-based communication. DDM is most commonly thought of for file sharing, but it can also be used for data areas and data queues. I'll describe how to configure data areas and data queues to utilize DDM and include a couple short examples of accessing data on a different system. I won't get into the configuration of DDM itself; I'll assume you already have a DDM environment that links two or more System i platforms.

Data areas and data queues are similar. They both store information in an unformatted state - there's no concept of records and fields as there is in a file. Commands can be used to display or change the contents of a data area, while performing the same actions on a data queue requires the use of an API call. A big difference is size - a data area can only be a maximum of 2,000 bytes, while a data queue can accommodate entries up to 64,512 bytes. They're both used for the same type of processing - relatively small amounts of information, especially information that may be accessed by several programs. For instance, this could be an invoice number, where an order-entry program would access the data area or data queue, retrieve and increment the invoice number, use the invoice number for the new order, and then put the updated invoice number back in the data area or data queue.

First, let's look at data areas and the command used to create one. Since I'm going to access this data area from two systems, I'll designate one system as the remote system (REMOTESYS) and the other as the local system (LOCALSYS). Sitting at a terminal on the remote system, I'll create a character-based data area (MRDTASRC) with this command:

CRTDTAARA DTAARA(MICHAEL/MRDTASRC)
     TYPE(*CHAR)
     LEN(50)
     TEXT('Source Data Area')

I'll then sign on to my local system - the system from which I'll access the contents of this data area. The command to create the DDM-based data area on the local system is:

CRTDTAARA DTAARA(MICHAEL/MRDTADST)
     TYPE(*DDM)
     RMTDTAARA(MICHAEL/MRDTASRC)
     RMTLOCNAME(REMOTESYS)
     TEXT('Destination Data Area')

Note the different parameters. I specified "*DDM" for the Data Area Type (TYPE) parameter. This means the data area I'm creating (MRDTADST) is a DDM "link" to a data area on a different system. The Remote Data Area (RMTDTAARA) parameter has a value of MICHAEL/MRDTASRC. This indicates that the actual data area to be accessed is a remote data area. And the system that contains the remote data area is specified in the Remote Location Name (RMTLOCNAME) parameter - I've specified REMOTESYS, the name of the remote system.


Once I've created the data areas, I can access the remote data area (MRDTASRC) from the local system. Here are a couple quick CL programs to test this out:

PGM
DCL    VAR(&MYVAR) TYPE(*CHAR) LEN(50)
DCL    VAR(&MSG) TYPE(*CHAR) LEN(125)
/* Change it...                  */
CHGVAR   VAR(&MYVAR) VALUE('12345')
CHGVAR   VAR(&MSG) VALUE('Setting the data area to' *BCAT &MYVAR)
SNDPGMMSG MSG(&MSG)
CHGDTAARA DTAARA(MICHAEL/MRDTADST) VALUE(&MYVAR)
ENDPGM

This program will change the remote data area to a new value ('12345'), and send the user a message. I get this message:

Setting the data area to 12345

Now I know the remote data area has been changed. Here's a program to retrieve the data from the remote data area:

PGM
DCL    VAR(&MYVAR) TYPE(*CHAR) LEN(50)
DCL    VAR(&MSG) TYPE(*CHAR) LEN(125)
/* Retrieve it...                 */
RTVDTAARA DTAARA(MICHAEL/MRDTADST) RTNVAR(&MYVAR)
CHGVAR VAR(&MSG) VALUE('And the data area contains' *BCAT &MYVAR)
SNDPGMMSG MSG(&MSG)
ENDPGM

Running this program produces this message:

And the data area contains 12345

Now I know the program accessed the remote data area.

The same concepts and techniques are used for data queues. Here's the command to create a data queue on the remote system:

CRTDTAQ DTAQ(MICHAEL/MRDTAQSRC)
    MAXLEN(100)
    TEXT('Source Data Queue')

Nothing special - just a 100-byte-long character-based data queue.

Here's the command to create the DDM-based data queue on the local system:

CRTDTAQ DTAQ(MICHAEL/MRDTAQDST)
    TYPE(*DDM)
    RMTDTAQ(MICHAEL/MRDTAQSRC)
    RMTLOCNAME(REMOTESYS)
    TEXT('Destination Data Queue')

Again, the Data Queue Type (TYPE), Remote Data Queue (RMTDTAQ) and Remote Location Name (RMTLOCNAME) parameters identify the data queue, the library where it resides and the remote system.

Here are two CL programs to test out the data-queue connectivity. The first is a program to send information from the local system to the remote system:

PGM
DCL    VAR(&MYDTAQVAR) TYPE(*CHAR) LEN(100)
DCL    VAR(&Msg) TYPE(*CHAR) LEN(125)
/* Send/Retrieve DtaQ Variables.         */
DCL    VAR(&DTAQNAM) TYPE(*CHAR) LEN(10) VALUE('MRDTAQDST')
DCL    VAR(&DTAQLIB) TYPE(*CHAR) LEN(10) VALUE('MICHAEL')
DCL    VAR(&DTAQSIZ) TYPE(*DEC) LEN(5 0) VALUE(100)
DCL    VAR(&DTAQWAT) TYPE(*DEC) LEN(5 0) VALUE(1)
/* Change it...                 */
CHGVAR   VAR(&MYDTAQVAR) VALUE('99999')
CHGVAR   VAR(&MSG) VALUE('Setting the message to' *BCAT &MYDTAQVAR)
SNDPGMMSG MSG(&MSG)
/* Send it...                   */
CHGVAR VAR(&DTAQSIZ) VALUE(100)
CALL PGM(QSNDDTAQ) PARM(&DTAQNAM &DTAQLIB &DTAQSIZ &MYDTAQVAR)
ENDPGM

And second is the program to retrieve the contents of the remote system's data queue:

PGM
DCL    VAR(&MYDTAQVAR) TYPE(*CHAR) LEN(100)
DCL    VAR(&MSG) TYPE(*CHAR) LEN(125)
/* Send/Retrieve DtaQ Variables.         */
DCL    VAR(&DTAQNAM) TYPE(*CHAR) LEN(10) VALUE('MRDTAQDST')
DCL    VAR(&DTAQLIB) TYPE(*CHAR) LEN(10) VALUE('MICHAEL')
DCL    VAR(&DTAQSIZ) TYPE(*DEC) LEN(5 0) VALUE(100)
DCL    VAR(&DTAQWAT) TYPE(*DEC) LEN(5 0) VALUE(1)
/* Retrieve DtaQ Value.              */
CALL    PGM(QRCVDTAQ) PARM(&DTAQNAM &DTAQLIB &DTAQSIZ &MYDTAQVAR &DTAQWAT)
CHGVAR   VAR(&MSG) VALUE('And the message is' *BCAT &MYDTAQVAR) SNDPGMMSG MSG(&MSG)
ENDPGM

The data-queue programs are a bit longer than the data-area programs, but they're not any more complex.

Sharing information between systems is easy with DDM-based data areas and data queues. There are no synchronization issues since data isn't copied between systems. Standard commands such as Change Data Area (CHGDTAARA) and Retrieve Data Area (RTVDTAARA), and standard API calls such as Send to Data Queue (QSNDDTAQ) and Receive from Data Queue (QRCVDTAQ) are used. Use these techniques when you need to access information on remote systems.



Questions for you [ Comment your answer ]




Section 1 – CL Command use

1)      Use of mon-message. A piece of code was given with the MONMSG at procedure level and it was asked where will the control go if an error happened in the processing of a command defined somewhere in the procedure.

2)      Command to write and read a file in CL.

3)      A call to a program is to submitted in batch and a customized library list is to be sent along with it.

4)      How to retrieve the job date/job name. Available options had RTVJOBA, RTVJOBD etc.

5)      CHGDTAARA command was given with a complex VALUE parameter which contained %SST. Was asked to mark the option, which gives the right value in the Data area.

6)      How can the current library list be changed.

7)      How to debug a program running in batch.

8)      A file with key A is to be accessed randomly on the basis of a field B. Available options  Create a new logical, Opnqry with STRSEQ parameter having B, Sorting the file etc.

9)      How to see the logical files created over a file by using CL command.

Section 2 – RPG Command use

1)      Where is the *INZSR subroutine coded.
2)      A field was defined with the like keyword. Was asked about its length and initial value.
3)      A DATFMT was defines at control spec. There were date definations at D spec. Was asked to recognize incorrect format.
4)      How is the format of a date defined at control specification level.
5)      %ELEM was used to define an array in the DIM keyword. Was asked how many records the array will have.
6)      Complex %subst using %scan with addition and subtraction done in the return value of SCAN.
7)      If DIV used with factor 2 zero what will happen. Options available Result indicator will be set on, *PSSR code will be executed, Result factor will have zero etc.
8)      A piece of code was given using DIV opcode where factor 2 was zero and *PSSR subroutine was coded. Was asked to detect what will happen.
9)      A data area DS was given and IN OUT operations performed. Among five different samples of code was asked to find out in which case the Data area will be locked and unlocked.
10)  How to find the Program name and some related information. Options had SDS etc.
11)  An expression using op-codes was to be converted using built in functions - %Dec and %DECH.
12)  What is the correct syntax for Op-code Test(D)
13)  When does a indicator defined in 73-74 position seton while chaining a record.
14)  Except keyword. A file defined in F spec as O type and a DS defined in D spec. How can the file be updated using the DS.

Section 3 – Advanced RPG Programming

1)      Complex Logical expression using Indicators and a variable. Analyzing and determine the result of the variable.
2)      Setting the indicator value by using logical expressions.
*IN50 = (A = B)
what will be the indicator value.
3)      With the same condition as above a complex piece of code was given and the result was to be determined.
4)      A complex logic in words using and either, or, neither to be written in expression.
5)      A complex piece of code with a variable using ITER and LEAVE was given and analyzing that code the value of that variable was to be determined.
6)      How to include a service program in your program.
7)      While creating the program if *OWNER is given to the usrprf parameter what is its significance.
8)      A program ‘A’ compiled with activation grp. *New calls a program ‘B’ compiled in activation grp. QILE. Program B has the following code: -

 Count = count + 1
 Seton     RT

After the program has been invoked 3 times. What will be the value of count?
9)      A Question on the same lines as above but not in different activation group. What will be the value of count?
10)  Where is a prototype defined.
11)  Select the right prototype definition. Extpgm definition was used?
12)  A piece of code for sub procedures was given. What is the length of the value returned?
13)  API for ovrdbf.

Section 4 – Subfiles

1)      There are some 200 records to be loaded. The roll up/down keys should be very fast. Which loading technique to be used.
2)      What does the keyword SFLNXTCHG do.
3)      What does the keyword SFLRCDNBR do.
4)       A piece of code was given using SFLRCDNBR. At what position the cursor will be?
5)      There was a piece of code having different keywords along with there indicators. What will be the indicator positions to initialize the sub file.
6)      If a record has been deleted and you don’t want do display it on the subfile anymore. What is the best possible way to do it?


Section 5 – RPG Performance and Exception/Error Handling

1)      There was some question where some data movement was done and then finally asked what will be the result. Available option Data truncation etc.

Section 6 – RPG Data Handling

1)   A multiple occurrence data structure was defined. How to set the occurrence using the OCCUR opcode.
2)      An EDS was defined using prefix but the fields were not renamed using EXTFLD. What will be the name of the fields used in the program.



Questoin bank 1


Question1:
How can you copy only 100 records in a file which contains millions of records?
(Ans)
By using CPYF command we can give the record copying position starting and ending of the records. If we want to copy the records between 1000 and 1100 in the million records we can give 1000 in the start position and 1100 in the end position.
In the another way by using CHGPF commands we can restrict the number of records to be there in a file by giving number of records as 100 and increments as 0.  In this case we can copy only the first 100 records and not possible to copy from one position to another.

Question2:
How to convert a field from Uppercase to lowercase?
(Ans)
By using XLATE command we can convert a field from upper to loew case or vice versa.
FDSPF001   CF   E             WORKSTN                                  
Dlower            S             26A   inz('abcdefghijklmnopqrstuvwxyz')
Dupper1           S             26A   inz('ABCDEFGHIJKLMNOPQRSTUVWXYZ')
C     *in03         doweq     *off                                     
C                   exfmt     casecon                                  
C   03              leave                                              
C                   if        *in09=*on                                
C     upper1:lower  XLATE     lowcase       upper                      
C                   endif                                              
C                   enddo                                               
C                   seton                                        lr    
Here lowcase and upper are the two fields in the screen and the user is entering characters in lowcase in upper case and convert that to upper case and move it to field upper when user press f9 key.

Question 3:
How to copy a file from as/400 system to a local pc.
(Ans)
Do the following to copy                                              
 ftp as/400 machine ip address                                         
 In wipro case      ftp 10.200.9.80                                                       
 It will ask for user name and password. Enter your as/400 user id and    password. It will then say the user has logged in successfully.         
 If you want to copy a rpgle program called load2 residing in shyamrlib library and source physical file name is shyamrile then we have to change the current library into shyamrlib .Just type cd shyamrlib and it will change the library. And then get shyamrile.load2 will copy the file into c:\ in local pc. If you want to copy from a PC to as/400 library then do the following
To do: Copy from c:\shyam\load2  to shyamrile\load2 in shyamrlib
Steps:
cd shyamrlib
put c:\shyam\load2 shyamrile.load2
will copy the file in shyam in c directory into shyamrile in shyamrlib.

Question 4:
How will your read a 100th record in a group of records in a file?
(Ans)
Declare the file without K in record address type in file definition.
z-add the position you want to retrieve. Suppose you want to retrieve 125th records
then z-add 125 to rrn
Do chain based on rrn.
fworkfile1 if   e             disk                                    
c                   z-add     2174          rrn1              4 0     
c     rrn1          chain     workfile1                          40   
c                   seton                                        lr   
Here we are reading the 2174th record.

Question 5:
Explain the usage of procedure in a life project
(Ans)
Here is a procedure which will accept the character in lower case and return the value in upper case. In java the user may enter either in lower or upper cases and we have to convert into uppercase else the chain will fail. So we create a procedure in our program which do this and call the procedure in our program.
Ex:
This is the program which is calling the procedure.
DPROC1            PR                                               
DX                              10A                                
DA                S             10A                                 
C                   EVAL      A='shyamsunda'                       
C                   CALLP     PROC1(                               
C                             A)                                   
c     A             dsply                                           
c                   seton                                        lr

The procedure
HNOMAIN                                                             
 DPROC1            PR            10A                                 
 D                               10A                                 
 PPROC1            B                   EXPORT                        
 DPROC1            PI            10A                                 
 DX                              10A                                  
 Dlower            S             26A   inz('abcdefghijklmnopqrstuvwxyz’)
 Dupper1           S             26A   inz('ABCDEFGHIJKLMNOPQRSTUVWXYZ’)
 C     lower:upper1  XLATE     X             X                       
 C                   RETURN    X                                     
 PPROC1            E    

Question 6:
How to query a record for getting the rrn value?
(Ans)
Select  rrn(zphamsp) from zphamsp where code=’AE’
Here zphamsp is the program name.

Question 7:
Is it possible to send arrays ,data structures as a parameter to another program?
(Ans)
Yes it is possible and we have to call in the same way a parameter is passed in the program.
Ex:
darr1             s              2p 0 dim(10)                     
darr2             s              2p 0 INZ(1)                      
c                               callB     'ARR2PGM'                           
C                              PARM                    ARR1                  
C     1                        DO        10                                  
C     ARR1(ARR2)    DSPLY                                         
C                              ADD       1             ARR2                  
C                              ENDDO                                          
c                               SETON                                        LR
called program
DARR1             S              2P 0 DIM(10)                     
DI                     S              2P 0 INZ(1)                      
C     *ENTRY        PLIST                                         
C                           PARM                    ARR1                  
C     1                    DO        10                                  
C                           EVAL      ARR1(I)=I                           
C                           ADD       1             I                     
C                           ENDDO                                         
C                           SETON                                        LR
Here the array is passed as a parameter and the values after callb is 1 to 10

Question 8:
What is the difference in between CALL, CALLB, CALLP
(Ans)
Call is a dynamic call where the control will be transferred when the program Is executed where as Callb and Callp are static calls.
A module is a non executable program and it contains one or more procedures. If you have modules without procedure then it means that it is having only one default procedure and in case we can use CALLB. But if a module is having more than one procedure then we can give explicitly the procedure name to be called in case of CALLP
Out of these three Callp is the most efficient one.

Question 9:
What is the new name for as/400?
(Ans)
Iseries 400 is the new name given to as/400 by IBM now.

Question 10:
How to see the source of copy books included in a program while compiling or debugging?
(Ans)
While Compiling the program give *list instead of *source which will expand all the copy books.

Question 11:
How to retrieve the value from data area and how to change the value of a data area?
(Ans)
ds                s             10a                                 
dg                s             10a   inz('i hate u')               
c     *dtaara       define    data1         s                       
c     *lock           in        s                                     
c                        eval      s=g                                   
c                        out       s                                     
c     s                  dsply                                           
c                         seton                                        lr 
I created a data area by using the command crtdtaara and give the length as 10a and value as I love you
Statement *dtaara       define    data1         s     
                *lock         in        s                                      will copy the content into a temporary variable s and now we are changing the value of s as I hate you and now by using out command the value of the data structure will be changed

Question 12:
How you will avoid multiple users updating the same record?
(Ans)
While displaying the records in the screen we will be getting the timestamp Along with the actual data. Store this in output data structure and while updating check weather the previous time stamp is the same timestamp before updating. If the record is updated by another user then the time stamp will be changed and if it does not matches then throw the error message ‘Record is already updated by another user’ else update the records with current time stamp
Program1
Store the time stamp and this time stamp will come as a input to the second program
Program 2
Here wstmst1 contains the input time stamp and check this matches with the database.If matches Update else send error message
C              K1CDFL        CHAIN     ZPCDFLR                            80
C                                     MOVEL     WSTMST1       WSTMST   
C                                     IF        CDMOTS=WSTMST                       
C                                     TIME                    CDMOTS                
C                                     UPDATE    ZPCDFLR                             
C                                     ELSE                                          
C                                     EVAL      ERROR=1                             
c                                      LEAVE                                         
C                                     ENDIF                                         
C                                     ENDDO                           

Question 13:
What will %size and %elem keywords will do?
 (Ans)
%size will display the size of the variable where as %elem will display the array dimension.

darr1             s              3s 0 dim(1000)                    
c                           eval      c=%size(arr1)                         
c                           eval      d=%elem(arr1)
c            c             dsply                          
c            d            dsply 
c                          seton                                        lr           

In the above program c will be 3 and d will be 1000

Question 14:
What will you format a number by using as/400?
 (Ans)
By using Editw Keyword
For example if you want to print 1234567890.12 as $1,234,567,890 dollars and 12 cents then the edit word must contains ‘$ ,   ,   ,   &dollars&and&  &cents.’
Here & will be used to add a space and a blank space represents the variable. So for printing and 12 cents we will give as &and&  12&cents. Where & represents blanks space in edit word and actual blank space is the variable 12.

dsalary           s             12p 2 inz(1234567890.12)               
dedit             c                   '$ ,   ,   ,   &dollars&and&  &cents’
damount           s             40a                                    
c                        eval      amount=%editw(salary:edit)               
c     amount        dsply                                              
c                       seton                                        lr    

Question 15:                     
How you can schedule a job to run periodically?
(Ans)
We have to create a job scheduler for running a job periodically. Here we can make a job to run once or periodically at a given date and time. . We can create a job scheduler by using addjobscde command.
We can list all the job scheduler running by using the command wrkjobscde and we can delete a job scheduler by using rmvjobscde or we can reschedule the job by using chgjobscde.

Question 16:               
How you can bind a C module with a RPG Program?
 (Ans)
Create a C module of type c
void logit (char *t)  
 {                     
 printf("'%s'\n",t);   
  }                    
And bind this program by calling it as a module in RPG program
D txt             S             40A   INZ('Hello, world !')   
D logit           PR                  EXTPROC('logit')        
                                                              
dtxt                              *   value OPTIONS(*STRING)  
                                                               
c                   CALLP     logit(%TRIMR(txt))              
c                   return                                    
Create program for this rpg by binding with the c module and call this program.

Question 17:
How to debug a batch job?
 (Ans)
Hold the batch job to be debuged by using wrkactjob command and having option 3. Set the pointer in the batch program to be debuged by using strdbg and then call the strsrvjob command and start the service program which will enter into the debug mode. After entering into debug mode release the job that is hold before.

Question 18:
Explain briefly about Non join Logical File.
(Ans)

Logical files can be derived from 1 to 32 physical files and so a logical file can have a maximum of 32 Record formats.
If a logical file is derived from single physical file without joining then it is single record format logical file.
Single record format logical file:
Refaccpth is applicable for Non join logical file only and meaning is refer the access path from the physical or the logical file in the file level entry.
PFILE is applicable only for non join logical file in record level entry.
               R RECPF2                    PFILE(PF02)         
               K EMPNAME                                      
Here the employee files key will be changed from empno to empname.
Output of this query is

No      NAME         ADDRESS1             ADDRESS2    CITY      STATE  ZIPCODE   
      1   SHYAM    29,ARUNA NAGAR    PUTHUR      TRICHY     TN         17     
      2   RAMBABU  29,ARUNA NAGAR PUTHUR      TRICHY     TN         17  
      3   SASI     53,KULALAR STREET                          CUMBUM   TN         54                
 ********  End of report  ********                                      
Here runqry will select all the records in pf02.
                            R RECPF2                    PFILE(PF02)               
                               EMPNAME       15A                                    
                               CITY          10A                                   
                           K EMPNAME                                             
Here the attribute size of city is changed from 30 to 10 and also the key value is changed.
The output of this query is
 EMPNAME          CITY           
 SHYAM            TRICHY         
 RAMBABU          TRICHY         
 SASI             CUMBUM       

               R RECPF2                    PFILE(PF02)                 
                   EMPNAME       15A                                    
                   CITY          10A                                    
                   EMPNO          5S 0                                  
               K EMPNAME                                              
               O EMPNO                     CMP(GT 2)                  
The output of this is 
  EMPNAME          CITY    empno       
 SHYAM            TRICHY    1     
 RAMBABU          TRICHY    2
Here the employee number 3 is omited since it is greater than 2.
         
Multiple record non join logical file will select records from 2 or more physical files by referring to only one logical file
1) Each record format is always associated with one or more physical file.
2) The same PF can be used in more than one record format.

Question 19:
Explain Inner join or natural join and left outer join.
(Ans)
Natural join
In case of natural join only the matching records in between the joining file will be selected.
If the pf of 2 files is like this
   PF01                                                                                PF02
   R JP1REC                                                                       R JP2REC
       EMPNO          5S 0                                                          EMPNO    5S 0
       EMPNAME       20A                                                       EMPSAL 15P 0
   K EMPNO                                                                         K EMPNO
The records in the 2 files are as follows
Empno       Empname                                             Empno      Empsal
1                  shyam                                                     1              1000000
2                 sundar                                                     2               2000000
3                 rambabu                                                 4                1000000         

Then in case of natural or inner join the records selected are

Empno       Empname                       Empsal
1                  shyam                                1000000
2                 sundar                                2000000

where as in Left outer join all the records from primary file and the matching records from the secondary file will be selected.
The output is
Empno       Empname                       Empsal
1                  shyam                                1000000
2                 sundar                                2000000
3                 rambabu                               0
Note that the salary will be defaulted to default values and the employee number 4 is not selected since this is the secondary file.

                R JL1REC                    JFILE(JP01 JP02)         
                 J                                  JOIN(1 2)                
                                                     JFLD(EMPNO EMPNO)        
                   EMPNO                    JREF(JP01)               
                   EMPNAME                                             
                   EMPSAL                                             
               K EMPNO              

Where as in inner join we have to specify jdftval in file level entry
                                          JDFTVAL               
              R JL2REC            JFILE(JP02 JP01)      
              J                           JOIN(1 2)             
                                          JFLD(EMPNO EMPNO)     
                EMPNO            JREF(JP02)            
                EMPNAME                                         
                EMPSAL                                          
              K EMPNO        
JFILE: It is similar to indicate that this is a Join logical file and it must have more than 2 physical files
Join : It indicates what are the files to be joined in this case. We can represent the position of the files. There must be one primary file and can have more than 1 secondary files.
JFLD which fields we are going to join 
JREF represent the primary file reference field.
JDFTVAL represents that it as a left outer join.    

If we are joining more than one Physical files then we can represent it as follows.
If the first two files are the same JP01 and JP02 and the third file to be joined is JP05
Which is having these fields
   R JP1REC                                    Empno     address
        Empno     5s 0                               1             Trichy
        Address  20a                                 2             Cumbum
    K empno
Then the result is

1                  shyam                 1000000                    trichy
2                 sundar                  2000000                     cumbum
which fetches the matching record in all the three files.
                                        JDFTVAL                 
            R JL5REC                    JFILE(JP01 JP02 JP05)   
            J                           JOIN(JP01 JP02)         
                                        JFLD(EMPNO EMPNO)       
            J                           JOIN(JP02 JP05)         
                                        JFLD(EMPNO EMPNO)       
              EMPNO                     JREF(JP01)              
              EMPNAME       20A                                  
              EMPSAL        15P 0                               
              ADDRESS                                           
            K EMPNO                                             

                              
Question 20
What will FOR opcode will do?
(Ans)
dn                s              5s 0 inz(10)                          
di                s              5s 0                    
 * for(i=0;i<n;i++)
c                   for       i=1 to n                                  
c     i             dsply                                              
c                   endfor                                             
 *  for(i=n;i<1;i--)                                                 
c                   for       i=n downto 1                             
c    i             dsply                                              
c                   endfor                                             
 *  for(i=5;i<40;i=i+10)                                              
c                   for       i=5 by n to 40                           
c     i             dsply                                              
c                   endfor                                             
c                                                                       
c                   for       i=5  to 40 by n                          
c     i             dsply                                              
c                   endfor                                         
c                                                                 
 *   for(i=5;i<40;i=i+10)                                             
c                   seton                                        lr

Question 21
What are the various stages for a job after it is submitted?
(Ans)
Jobqueue, Active job and OUTQ are the three stages after the job has been submitted.

Question 22
What are the difference between non join logical files and join logical files
(Ans)

Non Join Logical Files
Join Logical Files
We can able to insert or delete or update records using non join logical files.
Insertion, updating or deletion of records is not possible in join logical files
DFU  can be used to display Non join logical files
DFU is not available
1-32 record format can be specified
Only one record format can be specified
Commitment control is used
Commitment control is possible

Question 23
Explain Self join in detail
 (Ans)

In a employee physical file there are 3 fields named empno,empname and mgrid.
Manager is also an employee and he has an employee id in the same table with some other as manager. We want to query the records with the fields empno,empname and manager name. So based on the manager id we have to select the corresponding employee id and select the employee name and move that as the manager name.
DDS of  Physical File
SEU==>                                                                  PFTEST
 FMT PF .....A..........T.Name++++++RLen++TDpB......Functions++++++++++++++++++
        *************** Beginning of data *************************************
0001.00      A          R EMP                                                 
0002.00      A            EMPID          5  0                                  
0003.00      A            EMPNAME       20                                    
0004.00      A            MGRID          5  0                                 
        ****************** End of data ****************************************

Data in  Physical File
            EMPID   EMPNAME                          MGRID                                
000001 10,001   Sebi Joseph C.        50,001                                
000002 10,002   Purushottam             50,002                                 
000003 10,003   Sameer Dighe          50,003                                
000004 10,004   Sharada Menon                    50,004                                
000005 10,005   Saju Paul C.                          50,005                                
000006 50,001   Shivaram Pasuvan                90,001                                
000007 50,002   Praveen K. Gaurav                90,002                                
000008 50,003   Lionel King                          90,003                                
000009 50,004   Sam Mathew Varghese        90,004                                
000010 50,005   Anil Jandyam          90,005                                
****** ********  End of report  ********                                    


 FMT LF .....A..........T.Name++++++.Len++TDpB......Functions++++++++++++++++++
        *************** Beginning of data *************************************
0001.00      A          R EMP                                        JFILE(PFTEST PFTEST)      
0002.00      A          J                                      JOIN(1 2)                 
0003.00      A                                                   JFLD(MGRID EMPID)         
0004.00      A            EMPID                                      JREF(1)                   
0005.00      A            EMPNAME                               JREF(1)                   
0006.00      A            MANAGER                              RENAME(EMPNAME) JREF(2)   
0007.00                                                                        COLHDG('MANAGER')         
        ****************** End of data ****************************************

Output of Join Logical File


Line   ....+....1....+....2....+....3....+....4....+....5. 
              EMPID   EMPNAME               MANAGER              
000001 10,001   Sebi Joseph C.        Shivaram Pasuvan     
000002 10,002   Purushottam           Praveen K. Gaurav    
000003 10,003   Sameer Dighe          Lionel King          
000004 10,004   Sharada Menon         Sam Mathew Varghese  
000005 10,005   Saju Paul C.                Anil Jandyam         
****** ********  End of report  ********                   

Question 24:
What is a field reference file?
 (Ans)
This is a physical file which does not have any data and contains only the field descriptions and these fields are referred in other pf by using ref and reffld.
This is the third type of file along with PF and LF.

Question 25
What will runsqlstm will do?
(Ans)
If we want to execute set of sql statements (only insert, update and delete and no select is allowed) then we can write all the sql statement to be included with the source type as sql. Then use strsqlstm to execute the program
RUNSQLSTM SRCFILE(SHYAMRLIB/TESTSHYAM) SRCMBR(SQL1) COMMIT(*NONE)


Question 26
What is the advantage of Opnqryf over SQLRPG?
 (Ans)
opnqryf
sqlrpg
Opnqryf will come along with os/400 system and no need to have any additional package needed to execute it.
We need to have sqlrpg installed in as/400 system which involves additional cost to the programmers
Opnqryf is faster as compared to sqlrpg
It is slower
Opnqryf Is nothing but a dynamic logical files which will be created and the records are queried and finally the logical files are deleted and OPNQRYF provides that facility
SQLRPG is imbedding sql statements directly within SQL Statement


Question 27
What is the equivalent command to setll *loval in CL
 (Ans)
POSDBF with file position as *start will set the file to the beginning or using ovrdbf and specify the keyfield value by rrn value or by giving *start.

Question 28
What is the difference between OPM, EPM and RPGILE?
(Ans)
OPM
EPM
RPGLE
Open Program Model is the old RPG/400 system, which will not allow a program type to call another program type.
Extended program model will support PASCAL, FORTRAN and other programming concepts.
It supports mixed program support in which you can combine any program with another type of program

Version is V1R2
Version is V2R3

Question 29
What is the difference between Bind by value and Bind by reference?
(Ans)
Bind by value
Bind by Reference
Here all the modules to be bounded are physically copied into the main program object.
In this case we are binding the programs by using service programs which contains a reference to the modules that has been called and the modules are not physically copied into the program objects
The program will be executed even when you delete all the modules that have been called.
The program will not executed when the bind modules are deleted.
Bind by value is faster than bind by reference
It is not as faster as bind by value

Question 30
How to create a service program and what are the steps involved in this?
(Ans)
While creating service program we can create a binder program where we can refer the modules or procedures or even data types to be used by the program, which is using service program. If we are having 100 procedures in a module and if you want to specify only some procedures to be bind in the service program we can create the binder program.
        STRPGMEXP  SIGNATURE('BND')
         EXPORT SYMBOL('PGM1')     
        ENDPGMEXP                  
Here there are 2 programs PGM1 and pgm
                 PGM1                                                                                              PGM
 DA                S              2P 0 INZ(8)                                                         CALLB ‘PGM1’
 DB                S              2P 0 INZ(8)                                                          SETON         LR                        
 DC                S              2P 0                               
 C                   EVAL      C=A+B                                 
 C                   SETON                                        LR 

Then we create the binder program, which will give authority to only one module named PGM1
Then create the service program with binding program incorporated. If no binder program is incorporated then all the modules will be taken as default

CRTSRVPGM SRVPGM(QTEMP/SRVPGM) MODULE(QTEMP/XXXX) SRCFILE(IDCPGRRSP/SHYAMR
ILE) SRCMBR(BND)                                                               
                                                                                
DSPSRVPGM Will helps us to display the details about the service program that has been created.

We can also create a bind directory for a service program where we can bind all the modules together and if we do like this then there is no need to bind all the programs and we can compile the program straightly by using crtbndrpg even it has more than 1 module.
CRTBNDDIR BNDDIR(QTEMP/BNDDIR)
2)      ADDBNDDIRE BNDDIR(QTEMP/BNDDIR) OBJ((*LIBL/SRVPGM *SRVPGM))
The type of service program that is created is *srvpgm.

Question 31
What is an activation group?
 (Ans)
Activation group is the boundary set for similar programs. Activation group is also a storage space in memory.
Consider for example the following scenario

2)      CLP has a ovrdbf command and calls a rpg program
3)      RPG program performs a read operation and the pointer is now in the second program and now call the program 3
4)      RPG program that also do a read operation which will read the second record since the pointer is in the second position and then return to 2nd program
In the above situation when the control transfers from 3rd program to the 2nd program then it will read the 3rd record since the 2nd record is already read in program 3. But we need to read the 2nd record according to the logic but this is not possible in any OPM programs. But in ILE there is a solution for this problem by giving a common activation group for 1st and 2nd program and have a separate activation group for the 3rd program while creating the program itself and this will avoid all the problem we faced before.
In some situation we want to share between 2 programs then we can give the activation group in *job level in which the changes in one program will be affected in another program.
Types of activation group levels:
*new : In this case every time you call the program an new activation group will be created which this case will not be used mostly.
*caller: If we don’t know the type of the program that is calling then we can specify *caller where the activation group will be the same of the program that is calling.
Named activation group: We can give our own named for different activation group

Question 32
What are the statements that are affected by activation group?
(Ans)
1) OVRDBF
2) OPNQRYF
3) STRCMTCTL
4) DLTOVR
5) OPNDBF

Question 33
What are the statements, which is not used in CLLE that is used in CLP?
(Ans)
2)      RCLRSC which is replaced by RCLACTGRP
3)      TFRCTL

Question 34
Write a brief note on procedures used in RPGLE
 (Ans)

1) Defining the Prototype: Prototype will specify the following things
2)      Parameter type
3)      Sequence of the parameter
4)      Return variable and its type
5)      It tells the name of the procedure and also the type of the call.
It will avoid all the run time problems like parameter mismatch by specifying the prototype like this

2)      Prototype interface:
It is like the *entry parameter where we will specify the parameters that are received in this program.

3)      IMPORT and EXPORT
 If you want to specify the procedures to be used by the external programs then we can specify EXPORT in your procedure. If you don’t want then leave it blank. It is similar like giving private or public in JAVA.

4)      Global and local variables
If you declare a variable in main procedure then it will be accessible in all its sub procedure and this is global declaration and if you specify the declaration in the sub procedures then it will not be accessed in other procedures or in the main procedure.

5) RETURN
If we specify return in the sub procedure then it means that we are returning something to the calling program. We can return a maximum of only one variable to the calling program.

6) Recursion
A procedure calling to it self is known as recursion

7) Pass by value/Pass by reference
In case of pass by reference we are passing the address of the parameters and not the actual value and so the changes in the called procedure will affect the value in the calling programs. In OPM programs we are using only call by reference and in RPGLE we have the option to pass the parameter by value by giving the keyword VALUE

8) CALLP/Expression
We can call the procedure by using CALLP command if it is not having any return type and by an expression if it returns any value
Example
EVAL C=PROC1(A:B)
Example program doing recursion using procedure.
Called procedure:
H  NOMAIN                                                       
 DRECUR            PR             3S 0                            
 DA                               2S 0                           
  *                                                              
 DB                S              3S 0 INZ(1)                    
 PRECUR            B                   EXPORT                    
 D  RECUR          PI             3S 0                           
 D   A                            2S 0                           
 C                   IF        A<>1                              
 C                   EVAL      B = B*A                           
 C                   EVAL      A = A-1                           
 C                   CALLP     RECUR(A)                          
 C                   ENDIF                                       
 C                   RETURN    B                                 
 PRECUR            E                                             
  *                                   
Calling program
DVAL              S              2S 0 INZ(5)                         
DFACT             S              3S 0 INZ(1)                         
DRECUR            PR             3S 0                                
DA                               2S 0                                
C                                                                     
C                   EVAL      FACT = RECUR(VAL)                      
C     FACT          DSPLY                                            
C                   SETON                                        LR                              

Question 35
What is program entry procedure (PEP) and User entry procedure (UEP)
 (Ans)
If we are binding many modules together to form a program then we have to specify which module has to take control first when it has been called and that module is called as PEP for that program.
User entry procedure is the first statement that takes the control when a program has been called. For example in C programs main( ) will be executed first when it has been called and like wise in RPG the statement coded in C spec will take the control first.


Question 36
Explain about FMTDTA in detail.
 (Ans)
Here there is a pf of the following attributes
     R REC1              
       EMPNO          5S 0
       EMPNAME       20A 
       ADDRESS       25A 
       DOB            8S 0
And this physical file is having the following records
    Empno  name           address                       dob
      1   shyam                 trichy                     11,021,999
      2   tom                   pune                       11,122,002
      3   ccc                   jjhhj                      11,021,999
We want to sort the file based on address in ascending order then we have to code the format data in the following way.
IPRH and IPRF are used to add the attributes of format data.
  HFILE    025A         X                    pf02   
  FNC00260050                                address
  FDC00010058                             
Here we want to sort the physical file based on the address and the length of the field to be sorted is 25. If we want to sort based on more than 1 field (address,dob) then give the length as 33(25+8)
  HFILE    025A         X                    pf02   
The address position starts from 26th position to 50 and we have more fields declare all the fields by taking IPRF Spec
  FNC00260050                                address
After coding all the fields to be sorted give the total length of all the fields in the file. Here the file pf02 has a length of 58 and we declare it as follows
FDC00010058                              
The type of this program is anything even a text file. After coding the sorting manner we have to make use of format data command to create a file that contains the sorted record.
 FMTDTA INFILE((IDCPGRRSP/PF02)) OUTFILE(QTEMP/PF02) SRCFILE(IDCPGRRSP/SHYA
MRILE) SRCMBR(FMT)                                                             
This will copy the records into PF02/qtemp and the records will be sorted on address.
Output after sorting:
  EMPNO   EMPNAME               ADDRESS                           DOB  
      3   ccc                   jjhhj                      11,021,999  
      2   tom                  pune                       11,122,002  
      1   shyam                trichy                     11,021,999  

Question 37
What is the difference between FMTDTA and OPNQRYF
 (Ans)
FMTDTA
OPNQRYF
It will sort the records sequentially based on the position of the record.
It will sort the records based on the field values.
If any changes in the attribute size of a pf then we have to change the program specification also
If there is any change in the attribute size it will not affect the program specification also.
FMTDTA is bit faster in process than opnqryf.
OPNQRYF is slower as compare to FMTDTA if we are processing millions of records.

Question 38
How you can import and export a data type between 2 programs
 (Ans)
If you are using an export statement when declaring a variable then the data type can be imported in any modules that is bind either by value or by reference. So in this case we can pass values in between modules instead of using plist and *entry.
Program 1
DDD               S              2S 0 EXPORT INZ(1)                  
C                       CALLB     'EXP01'                                 
C     DD            DSPLY                                            
C                      SETON                                        LR  

Program 2
ddd               s              2s 0 import                       
c                   eval      dd=6                                 
c                   seton                                        lr

In the above example the value of the variable DD will be passed to the next program and it value is changed in the second program without using *entry and plist

Question 39
How you can use pointers in RPGLE
 (Ans)
Pointer is concept of referring the variable in the basis of address. We can make many variables or data structures that refer the same address space by using this pointer.
dbase_address     s               *                                  
 ddsname1          ds                  based(base_address)            
 dfirname                        10a                                  
 dlasname                        10a                                   
 ddsname2          ds            30                                   
 c                             eval      base_address=%addr(dsname2)            
 c                             eval      dsname2='shyam     sundar'              
 c          firname       dsply                                            
 c         lasname       dsply                                            
 c                            seton                                        lr  

Here in the above example we declare the pointer base_address and we make the datastructure dsname1 assigning to that pointer. We declare another data structure and till now the memory is not allocated to the pointer. Then by using the command
c                            eval      base_address=%addr(dsname2)            
we are allocating the address space to the pointer and since the data structure dsname1 is also referring this any change to dsname2 will affect dsname1. So assign some values to dsname2 and we can see the values in dsname1 also. Here the firname and lasname will print as shyam and sundar respectively.

Question 40
Discuss about option keyword in detail
 (Ans)
options(*varsize)  : It is similar to declaring the variable as varchar instead of char. So if we declare a variable with size 100 and if you initialize with shyam then it will allocate only 5 spaces.
Options(*nopass): This means that this parameter can be passed or even omitted
Options(*omit): We can give both *nopass and *omit for a single variable.
Options(*string): If we are passing string to the called program and if it is expecting the pointer then in such case we can give this option.
Please refer the question 16 for further clarification

Question 41
Explain EXTPGM in detail
 (Ans)
If we want to call a procedure dynamically then we can make use of this command
d prot1           pr                  extpgm('qcmdexc')           
 d cmdstr                      1000    options(*varsize)           
 D                                 CONST                       
 d cmdlen                      15s 5                             
 D                                  CONST                       
 d const1                       3    options(*nopass)            
 D                                  CONST                       
 D Cmds            C                   'DSPWSUSR'                  
 c                   callp     prot1(cmds:%len(cmds))              
 c                   seton                                        lr
In the above program example we are passing 3 variables to qcmdexc command for listing cl command.

Question 42
Explain O Spec and use of EXCEPT Opcode in detail
 (Ans)
O-Spec is used for printing records and except opcode is equal to writing the record format name in case of RLU.
We are printing all the records in the physical file pf02 whose has empno,name and address as the fields by using O-spec and except opcode.
fpf02      if   e             disk                                     
 fqsysprt   o    f  132        printer                                  
 dss               s             20a   inz('--------------------')      
 c*    *loval        setll     rec1                                     
 c                   read      rec1                                   80
 c                   except    header                                   
 c     *in80         doweq     *off                                     
 c                   except    detail                                   
 C                   read      rec1                                   80
 c                   enddo                                              
 c                   seton                                        lr    
  *                                                                      
 oqsysprt   e            header                                         
 o                       ss                  20                         
 o                       ss                  40                         
 oqsysprt   e            detail                                         
o                       empno                5         
 o                       empname             25         
 o                       address             45         
 ****************** End of data *************************
The output of the spooled file is
----------------------------------------   
 00001shyam          trichy                 
 00002tom            pune                   
 00003ccc            jjhhj