× The internal search function is temporarily non-functional. The current search engine is no longer viable and we are researching alternatives.
As a stop gap measure, we are using Google's custom search engine service.
If you know of an easy to use, open source, search engine ... please contact support@midrange.com.



Sorry, I forgot to add some definitions that you'll need to use some of that 
code.  Here's a more complete version.



-----Original Message-----
From: Mike Haston ** Data 
Sent: Thursday, April 03, 2003 8:08 AM
To: RPG programming on the AS400 / iSeries
Subject: RE: Dynamic embedded OPNQRYF in RPG


Hopefully this will help.  You can use scan & replace a little differently, but 
this is the general idea of OPNQRYF in an RPGLE program.


-----Original Message-----
From: heba refaie [mailto:heba_refaie@xxxxxxxxxxx]
Sent: Tuesday, April 01, 2003 5:04 AM
To: RPG400-L@xxxxxxxxxxxx
Subject: Dynamic embedded OPNQRYF in RPG


Hi Group,

I need an example to show how to use Dynamic embedded OPNQRYF in RPGLE 
program, if possible.

For example, if I have FileA which is a holding file and I would like to 
select all the expired orders where  ExpDat = :Today's date .

I searched in the archives but could not find a published example, although 
the question was asked before.

Thanks beyond measures,
All the best.
Heba







     h bnddir( 'QC2LE' )
     h dftactgrp( *no )

     fSUS100AL  uf   e             disk    usropn

     d @qcmdexc        pr            10i 0 extproc( 'system' )
     d command                         *   value options( *string )

     d cmd             s           3000a
     d string          s             80a   dim(2) ctdata perrcd(1) varying
     d today           s               d   inz(*job)
     d today#          s              8s 0

     c                   move      today         today#

      /free

       // OVRDBF

       @qcmdexc( 'OVRDBF FILE(SUS100AL) SHARE(*YES)' );

       // OPNQRYF

       cmd = string(1) + ' ' + string(2);
       cmd = %replace( %editc(today# : '4') : cmd : %scan('########' : cmd) );
       @qcmdexc( cmd );

       if not %open( SUS100AL );
         open SUS100AL;
       endif;

       // read thru file and flag all records which have been pulled in via
       // the OPNQRY.

       read SUS100AL;
       dow not %eof( SUS100AL );

         %subst( PA_XT2 : 1 : 1 ) = 'P';
         update PA_REC;

         read SUS100AL;
       enddo;

       // CLOF and DLTOVR

       @qcmdexc( 'CLOF OPNID(SUS100AL)' );
       @qcmdexc( 'DLTOVR FILE(*ALL)' );

       *inlr = *on;

      /end-free

**
OPNQRYF FILE((SUS100AL)) OPTION(*ALL) QRYSLT('PA_ERROR = "Y"
*AND PA_PDATE = ########')

As an Amazon Associate we earn from qualifying purchases.

This thread ...


Follow On AppleNews
Return to Archive home page | Return to MIDRANGE.COM home page

This mailing list archive is Copyright 1997-2025 by midrange.com and David Gibbs as a compilation work. Use of the archive is restricted to research of a business or technical nature. Any other uses are prohibited. Full details are available on our policy page. If you have questions about this, please contact [javascript protected email address].

Operating expenses for this site are earned using the Amazon Associate program and Google Adsense.