SQLSTATE = 42601;SQLCODE = -104 ;MAXCC= 16



Unicenter CA-Easytrieve Plus Report Generator: CA's information retrieval and data management tool

SQLSTATE = 42601;SQLCODE = -104 ;MAXCC= 16

Postby Kshitij_07 » Sun Mar 31, 2013 7:52 pm

Hi All,

I am receivinG maxcc = 16 & SQL state as 42601 with 104 sqlcode after submitting my job.

The JCL with the easytrieve program submitted was coded as below:

//WIP04DD JOB (T,476),'KSHITIJ',CLASS=1,MSGCLASS=X,             
// NOTIFY=&SYSUID                                               
//************************************************************* 
//EZTSQL   EXEC PGM=EZTPA00,REGION=4M                           
//************************************************************* 
//STEPLIB  DD  DSN=SYSTEMS.LINKLIB,DISP=SHR                     
//         DD  DSN=DB2P.SDSNLOAD,DISP=SHR                       
//EZTVFM   DD  SPACE=(CYL,(20,20)),UNIT=SYSDA,DCB=BUFNO=40       
//SYSPRINT DD  SYSOUT=*                                         
//SYSPUNCH DD  DUMMY                                             
//SYSOUT   DD  SYSOUT=*                                         
//SYSUDUMP DD  SYSOUT=Y                                         
//SORTWK01 DD  SPACE=(CYL,(5,50)),UNIT=SYSDA                     
//SORTWK02 DD  SPACE=(CYL,(5,50)),UNIT=SYSDA                     
//INFILE   DD DSN=CCS.WIP04.CMRREP,                             
//         DISP=SHR                                             
//*        DISP=(NEW,CATLG,DELETE),                             
//*        DCB=(RECFM=FB,LRECL=30),   
//OUTFILEA DD DSN=CCS.WIP04.CMRO1,                           
//         DISP=(NEW,CATLG,DELETE),                         
//         DCB=(RECFM=FB,LRECL=80),                         
//         DATACLAS=MB050                                   
//*        DISP=(NEW,CATLG,DELETE),                         
//*        DCB=(RECFM=FB,LRECL=80),                         
//*        DATACLAS=MB050                                   
//SYSIN DD *                                                 
PARM           +                                             
BIND(DYNAMIC)+                                                 
DB2SSID('DB2P')+                                             
DEBUG(FLOW)                                                 
FILE INFILE                                                 
     IN-REC     1  080   A                                   
     IN-CLM-NO 01   12   A                                   
FILE OUTFILEA                                               
    OUT-REC        1   080  A                               
    OUT-SALN       1    8   A                               
    OUT-GR-RSV     10   14  A                               
    OUT-NET-RSV    25   14  A   
    OUT-RP-GR-RSV  40   14  A   
    OUT-RP-NET-RSV 55   14  A   
WS-CRNCL                 W  12 A                                     
WS-SALN                  W  08 A                                     
WS-SALN1                 W  08 A                                     
WS-GR-RSV                W  14  A                                     
WS-NET-RSV               W  14  A                                     
WS-RP-GR-RSV             W  14  A                                     
WS-RP-NET-RSV            W  14  A                                     
  *                                                                   
  SQL DECLARE GETRSRV CURSOR FOR                                   + 
     SELECT  GROSS_RESV_AMT,NET_RESV_AMT,RLP_GROSS_RESV_AMT,       + 
             RLP_NET_RESV_AMT                                      + 
       FROM DB2P.DFCSP.FI_UNIT_HISTORY                             + 
          WHERE   SALN = :WS-SALN1                                 + 
          AND CURRENT_IND = 'C'                                    + 
      WITH UR                                                         

JOB INPUT INFILE FINISH (WINDUP)
SQL   +                                             
 SELECT SALN FROM DB2P.DFCSP.CLM_COVERAGE   +     
 INTO :WS-SALN  +                                   
 WHERE CRN_CLM_NO = :IN-CLM-NO +                   
 WITH UR                                           
                                                   
   IF SQLCODE NE 0                                 
      DISPLAY 'NO ENTERIES ' SQLCODE ' CRN CLM#: ' 
     STOP                                           
  END-IF                                           
  IF SQLCODE = 0                                   
      WS-SALN1 = WS-SALN                                     
  END-IF                                                     
SQL OPEN GETRSRV                                             
   IF SQLCODE NE 0                                           
      DISPLAY 'CURSOR OPEN ERROR : ' SQLCODE ' CRN CLM#: '   
     STOP                                                   
  END-IF                                                     
  IF SQLCODE = 0                                             
    PERFORM FETCH-PARA                                       
  END-IF                                                     
 *                                                           
FETCH-PARA. PROC.                                           
    SQL FETCH GETRSRV      +                                 
      INTO :WS-GR-RSV,     +                                 
           :WS-NET-RSV, +                                   
           :WS-RP-GR-RSV, +                                 
           :WS-RP-NET-RSV                                   
  IF SQLCODE = 100                                           
      DISPLAY 'NO MORE RECORDS FOR THIS SALN'             
   END-IF                                                 
   IF SQLCODE = 0                                         
      DISPLAY 'NET RESERVE' WS-NET-RSV                   
      OUT-GR-RSV       = WS-GR-RSV                       
      OUT-NET-RSV      = WS-NET-RSV                       
      OUT-RP-GR-RSV    = WS-RP-GR-RSV                     
      OUT-RP-NET-RSV   = WS-RP-NET-RSV                   
      OUT-SALN         = WS-SALN1                         
      PUT OUTFILEA                                       
   END-IF                                                 
      IF SQLCODE NE 0 AND SQLCODE NE 100                 
         DISPLAY 'CURSOR FETCH ERROR : ' SQLCODE         
         STOP                                             
      END-IF                                             
      SQL CLOSE GETRSRV                                   
      DISPLAY ' SQL CODE : ' SQLCODE                     
 END-PROC.                                               
         WINDUP. PROC.     
           DISPLAY 'DONE '
        END-PROC.         



The error details are as follows:
SELECT SALN FROM DB2P.DFCSP.CLAIM_COVERAGE  +                                 
 INTO :WS-SALN  +                                                               
 WITH UR                                                                       
 SQL - SQL ERROR, SQLCODE IS -104                                               
 SQL - DSNT408I SQLCODE = -104, ERROR:  ILLEGAL SYMBOL "?". SOME SYMBOLS THAT MI
SQL -          ARE: <END-OF-STATEMENT> QUERYNO HAVING WHERE GROUP ORDER INTERSE
SQL - DSNT418I SQLSTATE   = 42601 SQLSTATE RETURN CODE                         
 SQL - "SELECT INTO" IS VALID ONLY FOR SQLSYNTAX OF NONE AND STATIC-ONLY BIND   


The select query seems fine & the fields (used in the query)seem to be populated as well.
Instead of DYNAMIC, i tried giving STATIC,NONE & STATIC-ONLY values in the BIND parameter, but the error 'parameter invalid' would come up.

Please let me know if anybody has come across this error & if you require more details on this.

Thanks a LOT !!!!
Kshitij_07
 
Posts: 11
Joined: Thu Feb 21, 2013 2:35 pm
Has thanked: 3 times
Been thanked: 0 time

Re: SQLSTATE = 42601;SQLCODE = -104 ;MAXCC= 16

Postby NicC » Sun Mar 31, 2013 9:21 pm

Obviously your select statement is NOT fine as it is giving -104. You have looked up -104 haven't you? Why do you have '+' at the end of each line? They are not an SQL coninuation - SQL does not need one although easytrieve may. Double check in the manual.
The problem I have is that people can explain things quickly but I can only comprehend slowly.
Regards
Nic
NicC
Global moderator
 
Posts: 3026
Joined: Sun Jul 04, 2010 12:13 am
Location: Pushing up the daisies (almost)
Has thanked: 4 times
Been thanked: 136 times

Re: SQLSTATE = 42601;SQLCODE = -104 ;MAXCC= 16

Postby Kshitij_07 » Mon Apr 01, 2013 12:10 am

hi nic


the + sign is for the continuation of the sql statement.
can you please share your opinion on the sqlstate ?
Kshitij_07
 
Posts: 11
Joined: Thu Feb 21, 2013 2:35 pm
Has thanked: 3 times
Been thanked: 0 time

Re: SQLSTATE = 42601;SQLCODE = -104 ;MAXCC= 16

Postby Kshitij_07 » Mon Apr 01, 2013 12:13 am

+ sign is required for continuation of sql statement in easytrieve i meant
Kshitij_07
 
Posts: 11
Joined: Thu Feb 21, 2013 2:35 pm
Has thanked: 3 times
Been thanked: 0 time

Re: SQLSTATE = 42601;SQLCODE = -104 ;MAXCC= 16

Postby dick scherrer » Mon Apr 01, 2013 6:14 am

Hello,

Have you looked in the maniual for the description of the error?

Read here:
http://publibz.boulder.ibm.com/cgi-bin/ ... 0637&CASE=
Hope this helps,
d.sch.
User avatar
dick scherrer
Global moderator
 
Posts: 6269
Joined: Sat Jun 09, 2007 8:58 am
Has thanked: 3 times
Been thanked: 93 times

Re: SQLSTATE = 42601;SQLCODE = -104 ;MAXCC= 16

Postby Kshitij_07 » Mon Apr 01, 2013 4:26 pm

Hi Dick,

Yes, I checked.. I checked with my collegues & it turns out I had to use a cursor here..went wrong functionally. :oops:
Thanks for the information.
Kshitij_07
 
Posts: 11
Joined: Thu Feb 21, 2013 2:35 pm
Has thanked: 3 times
Been thanked: 0 time

Re: SQLSTATE = 42601;SQLCODE = -104 ;MAXCC= 16

Postby dick scherrer » Tue Apr 02, 2013 12:36 am

Good to hear it is resolved - thank you for letting us know :)

d
User avatar
dick scherrer
Global moderator
 
Posts: 6269
Joined: Sat Jun 09, 2007 8:58 am
Has thanked: 3 times
Been thanked: 93 times


Return to CA-Easytrieve