SAS - Proc SQL



Post anything related to mainframes (IBM & UNISYS) if not fit in any of the above categories

SAS - Proc SQL

Postby rbunster » Thu Sep 08, 2016 10:00 pm

Hello,

I have done a sas code using PROC SQL and I am wondering how can I do to throw my proc sql table into a flat file, see my code below:
000008 //GO       EXEC SAS,WORK='3000,900'                                    
000009 //SASLIST  DD SYSOUT=*                                                
000010 //ENTRE1 DD DISP=SHR,DSN=PE5A.MFFFF001.S031020G(0)                    
000012 //SORTIE DD DSN=UE5A.MFFFF001.COUNT.IV,                              
000013 //          UNIT=SYSALLDA,DISP=(,CATLG,DELETE),                      
000014 //          DCB=(DSORG=PS,RECFM=FB,LRECL=100,BLKSIZE=0),              
000015 //          SPACE=(CYL,(1,10),RLSE)                                  
000016 //SSAVE DD *                                                          
000017 //SYSIN DD *                                                          
000018 DATA IV;                                                              
000019    INFILE ENTRE1;                                                      
000020    INPUT @056 SDU                  $CHAR2.                            
000021          @085 SYS_EMET             $CHAR2.                            
000022          @149 ANNE_RECEP           4.                                  
000023          @153 MOIS_RECEP           2.                                  
000024          @279 IND_ASSOC            $CHAR1.;                            
000025    RUN;                                                                
000026                                                                        
000027 PROC SQL;                                                              
000028    CREATE TABLE IV_PREP  AS                                            
000029    SELECT                                                              
000030          SDU,                                                          
000031          SYS_EMET,                                                    
000032          CASE                                                          
000033             WHEN MOIS_RECEP <= 3                                      
000034                THEN ANNE_RECEP - 1                                    
000035             ELSE                                                      
000036                ANNE_RECEP                                              
000037          END AS EXERCICE,                                              
000038          IND_ASSOC                                                    
000039    FROM IV                                                            
000040    ;                                                                  
000041 QUIT;                                                                  
000042                                                                        
000043 PROC SQL;
000043    CREATE TABLE IV_EXEC  AS                                                                
000044    SELECT                                                              
000045          EXERCICE AS IVC_EXERCICE,                                    
000046          IND_ASSOC AS IVC_IND_ASSOC,    
000047          COUNT(IND_ASSOC)   AS QTT_IND_ASSOC                  
000048    FROM  IV_PREP                                              
000049    GROUP BY EXERCICE, IND_ASSOC                              
000050    ;                                                          
000051 QUIT;                                                        
000052 /*      


The table I want to send to the SORTIE dataset is IVC_EXEC.

I have tried many ways like DATA _NULL_ or PROC Export, but none of them really worked

Thank you for your help
rbunster
 
Posts: 1
Joined: Thu Sep 08, 2016 8:14 pm
Has thanked: 0 time
Been thanked: 0 time

Re: SAS - Proc SQL

Postby Robert Sample » Fri Sep 09, 2016 12:24 am

I have tried many ways like DATA _NULL_ or PROC Export, but none of them really worked
You are not telling us what you tried here, so we have no idea if you miscoded something. Nor did you say HOW they didn't work -- SAS error? JCL error? executed but produced no output? executed but produced unexpected output? something else entirely? Based on what you've posted so far, all we could possibly do is guess as psychic day was yesterday.
Robert Sample
Global moderator
 
Posts: 3719
Joined: Sat Dec 19, 2009 8:32 pm
Location: Dubuque, Iowa, USA
Has thanked: 1 time
Been thanked: 279 times

Re: SAS - Proc SQL

Postby Robert Sample » Fri Sep 09, 2016 1:53 am

You want a sequential data set, NOT a "flat file". The only files on a z/OS system are either or tape or in Unix System Services. Everything else is a data set. Terminology is critical in IT where similar terms may mean very different things.

This code produces data in my sequential data set:
PROC SQL ;                  
      CREATE TABLE JOBTABLE AS
      SELECT * FROM JOBS      
      ;                      
 RUN;                        
                             
 DATA _NULL_ ;                
      SET JOBTABLE;          
      FILE DDOUT ;            
      PUT @001 JOB      $8.  
          @010 JESNR    Z8.  
          @020 CONDCODE      
          @030 EXCPTOTL 8.    
          @040 CPUTM    8.    
          ;                  
so if you say you tried DATA _NULL_, you obviously did not code it correctly.
Robert Sample
Global moderator
 
Posts: 3719
Joined: Sat Dec 19, 2009 8:32 pm
Location: Dubuque, Iowa, USA
Has thanked: 1 time
Been thanked: 279 times


Return to All other Mainframe Topics