fhg
Volume 6, Number 31 -- August 23, 2006

Quick Query Over a Database File

Published: August 23, 2006

Dear esteemed professional colleagues:

Today's tip is not rocket science, but as I have said before, rocket science won't help me keep the factory running. Today I share with you a utility that I use constantly, day-in and day-out. Maybe some of you will find it handy as well.

The utility of the day is a command I wrote years ago to help me with testing. As you well know, when you're testing a program, you often have to look at database files to make sure they were modified correctly. The Display Physical File Member (DSPFFM) command is helpful sometimes, but it suffers from a couple of glaring problems, namely (1) the fields are jammed together and (2) packed and binary data is not easy for humans to read. I wrote the Query File (QF) utility as a way to quickly view the contents of a database file in a legible format.

The QF utility consists of two objects: a command and an OPM CL program. Here's the source for command QF:

/* =============================================================== */
/* Command: QF                                                     */
/* Program: QFC                                                    */
/* Purpose: Query a file                                           */
/*                                                                 */
/* To create:                                                      */
/*                                                                 */
/* CRTCMD CMD(xxx/QF) PGM(xxx/QFC) SRCFILE(xxx/QCMDSRC) SRCMBR(QF) */
/* ================================================================*/
                                                                   
             CMD        PROMPT('Query a file')                     
             PARM       KWD(FILE) TYPE(Q1) MIN(1) PROMPT('File')   
 Q1:         QUAL       TYPE(*NAME) MIN(1) EXPR(*YES)              
             QUAL       TYPE(*NAME) DFT(*LIBL) SPCVAL((*LIBL) +    
                          (*CURLIB)) EXPR(*YES) PROMPT('Library')  
             PARM       KWD(MBR) TYPE(*NAME) DFT(*FIRST) +         
                          SPCVAL((*FIRST) (*LAST)) EXPR(*YES) +    
                          PROMPT('Member')                         
             PARM       KWD(DEVICE) TYPE(*CHAR) LEN(1) RSTD(*YES) + 
                          DFT(D) VALUES(D P) EXPR(*YES) +          
                          PROMPT('Output to display or printer?')
             PARM       KWD(SELECT) TYPE(*CHAR) LEN(1) RSTD(*YES) +
                          DFT(N) VALUES(Y N) EXPR(*YES) +          
                          PROMPT('Select records?')

Here's the source for OPM CL program QFC:

/* =================================================================*/ 
/* Program: QFC                                                     */ 
/* Command: QF                                                      */ 
/* Purpose: Query a file                                            */ 
/*                                                                  */ 
/* To create:                                                       */ 
/*                                                                  */ 
/*    CRTCLPGM   PGM(xxx/QFC) SRCFILE(xxx/QCLSRC) SRCMBR(QFC)       */ 
/* =================================================================*/ 
            
pgm (&QualFile &Mbr &Device &Select) 
                                     
   dcl &QualFile *char   20          
   dcl &Mbr      *char   10          
   dcl &Device   *char    1 /* d=display, p=printer */ 
   dcl &Select   *char    1                            
   dcl &RcdSlt   *char    4 value(*NO)
   dcl &OutType  *char   10 value(*DISPLAY)    
                                               
      dcl   &Abending      *lgl                
      dcl   &MsgDta        *char    256        
      dcl   &MsgF          *char     10        
      dcl   &MsgFLib       *char     10        
      dcl   &MsgID         *char      7        
      dcl   &PgmName       *char     10        
      dcl   &RtnType       *char      2        
                                               
      monmsg (cpf0000 qry0000) exec(goto abend)
                                               
   if (&Select *eq 'Y' *or &Select *eq 'y') +  
      then(chgvar &RcdSlt '*YES')              
                                               
   if (&Device *eq 'P' *or &Device *eq 'p') +  
      then(chgvar &OutType '*PRINTER')

   runqry qryfile((%sst(&QualFile 11 10)/%sst(&QualFile 1 10) &Mbr)) + 
 outtype(&OutType) rcdslt(&RcdSlt) prtdfn(*NO)             
   return                                                              
/* ===========================================================*/ 
/* * Routine to handle unexpected errors */                      
Abend:                                                           
/* Don't let this program go into a loop here. */                
      if &Abending then(do)                                      
         sndpgmmsg  msgid(cpf9898) msgf(qcpfmsg) msgtype(*escape) + 
                      msgdta('Program' *bcat &PgmName *bcat +    
                             'ended abnormally at label Abend') 
         monmsg cpf0000  
         return          
      enddo              
      chgvar   &Abending '1' 
                             
/* Resend diagnostic & escape messages to the caller          */ 
/* caller as diagnostic messages.                             */
RcvDiag:                                                         
      rcvmsg     msgtype(*diag) msgdta(&msgdta) msgid(&msgid) + 
rtntype(&RtnType) +                          
                    msgf(&msgf) sndmsgflib(&msgflib)             
      if (&RtnType *eq '02') do                                  
         sndpgmmsg  msgid(&msgid) msgf(&msgflib/&msgf) +         
                   msgdta(&msgdta) msgtype(*diag)                
         goto RcvDiag                                            
      enddo                                                      
                                                                 
RcvEscape:                                                       
      rcvmsg     msgtype(*excp) msgdta(&msgdta) msgid(&msgid) +  
                    rtntype(&RtnType) +            
                    msgf(&msgf) sndmsgflib(&msgflib)             
      if ((&RtnType *eq '15') *or (&RtnType *eq '17')) do        
         sndpgmmsg  msgid(&msgid) msgf(&msgflib/&msgf) +         
                   msgdta(&msgdta) msgtype(*diag)                
      enddo

/* ========================================================== */
Escape:                                                        
 /* cancel the program */                                      
      sndpgmmsg  msgid(cpf9898) msgf(qcpfmsg) msgtype(*escape) +
                   msgdta('QF command ended abnormally')       
endpgm

QF has four parameters:

  1. A qualified file name
  2. A file member (default is *FIRST)
  3. Whether the file data is to be displayed (D) or printed (P)
  4. Whether or not the record selection panel is to be presented (Y or N)

Here are some examples of how you might use the QF command.

qf qiws/qcustcdt
qf qcustcdt select(y)
qf myfile mbr(m2005)

QF runs the Run Query (RUNQRY) command, so it doesn't do anything you can't already do, but it's much easier to type.

--Ted



Sponsored By
WORKSRIGHT SOFTWARE

Do you need area code information?
Do you need ZIP Code information?
Do you need ZIP+4 information?
Do you need city name information?
Do you need county information?
Do you need a nearest dealer locator system?

We can HELP! We have affordable AS/400 software and data to do all of the above. Whether you need a simple city name retrieval system or a sophisticated CASS postal coding system, we have it for you!

The ZIP/CITY system is based on 5-digit ZIP Codes. You can retrieve city names, state names, county names, area codes, time zones, latitude, longitude, and more just by knowing the ZIP Code. We supply information on all the latest area code changes. A nearest dealer locator function is also included. ZIP/CITY includes software, data, monthly updates, and unlimited support. The cost is $495 per year.

PER/ZIP4 is a sophisticated CASS certified postal coding system for assigning ZIP Codes, ZIP+4, carrier route, and delivery point codes. PER/ZIP4 also provides county names and FIPS codes. PER/ZIP4 can be used interactively, in batch, and with callable programs. PER/ZIP4 includes software, data, monthly updates, and unlimited support. The cost is $3,900 for the first year, and $1,950 for renewal.

Just call us and we'll arrange for 30 days FREE use of either
ZIP/CITY or PER/ZIP4.

WorksRight Software, Inc.
Phone: 601-856-8337
Fax: 601-856-9432
E-mail: software@worksright.com
Web site: www.worksright.com



Senior Technical Editor: Ted Holt
Technical Editors: Howard Arner, Joe Hertvik, Shannon O'Donnell, Kevin Vandever
Contributing Technical Editors: Joel Cochran, Wayne O. Evans, Raymond Everhart,
Bruce Guetzkow, Brian Kelly, Marc Logemann, David Morris
Publisher and Advertising Director: Jenny Thomas
Advertising Sales Representative: Kim Reed
Contact the Editors: To contact anyone on the IT Jungle Team
Go to our contacts page and send us a message.

Sponsored Links

iTera:  High availability - Are you prepared in case of tornado? One customer is.
Patrick Townsend & Associates:  Alliance AES/400 - database field encryption
COMMON:  Join us at the Fall 2006 conference, September 17-21, in Miami Beach, Florida

 


 
Subscription Information:
You can unsubscribe, change your email address, or sign up for any of IT Jungle's free e-newsletters through our Web site at http://www.itjungle.com/sub/subscribe.html.

Copyright © 1996-2008 Guild Companies, Inc. All Rights Reserved.
Guild Companies, Inc., 50 Park Terrace East, Suite 8F, New York, NY 10034

Privacy Statement