|
Very cool that this topic just came up. I'm real new to SQL of any type, in fact you helped me not long ago Tracy. Yesterday I stumbled upon the 'prepare' SQL and figured I'd give it a shot. The term spaghetti code comes to mind when looking at what I'm doing, but I didn't know how to attack this any other way but to build the entire statement. I have a selection screen where I can enter 0-20 store#'s, a date range, 0-5 divisions and 0-5 seasons. I'm building the SQL statement the way I used to fumble around with OPNQRYF. You'll see in the attached! Mike -----Original Message----- From: Tracy Ball [mailto:TBall@xxxxxxxxxxxxxxxx] Sent: Tuesday, February 25, 2003 12:48 PM To: RPG programming on the AS400 / iSeries Subject: RE: SQLRPGLE - Dynamic selection Does the nulls field have any bearing on the syntax here at all? This is a great example. From what I can see, I am doing pretty much all these things in just a much simpler text, yet don't get the results. I will use this as a model. Thank you very much!! -Tracy Ext. 3107 -----Original Message----- From: MWalter@xxxxxxxxxxxxxxx [mailto:MWalter@xxxxxxxxxxxxxxx] Sent: Tuesday, February 25, 2003 12:39 PM To: RPG programming on the AS400 / iSeries Subject: Re: SQLRPGLE - Dynamic selection something like this: DgetItemData PR 40 D itnbr 15 CONST D year 4 0 CONST PgetItemData B Export DgetItemData PI 40 D itnbr 15 CONST D year 4 0 CONST ditemDS ds D itdsc 30 overlay(itemDs:*next) D itcls 4 overlay(itemds:*next) D itacim 3 overlay(itemDs:*next) D unmsr 2 overlay(itemDs:*next) D valuc 1 overlay(itemDs:*Next) Dnulls S 5i 0 DsqlStmt S 250 DfileName S 21 c reset itemDs c eval fileName = 'Yearend/Itemasa' + c %subst(%editc(year:'X'):3:2) c eval sqlStmt = 'SELECT itdsc, itcls, itacim, + c unmsr, valuc + C FROM ' + %trim(fileName) + C ' WHERE itnbr = ''' + C %trim(itnbr) + '''' C/exec sql C+ PREPARE stmt from :sqlStmt c/end-exec c/exec sql c+ DECLARE c CURSOR FOR stmt c/end-exec c/exec sql c+ OPEN c c/end-exec c/exec sql C+ FETCH c INTO :itemDS :nulls c/end-exec c/exec sql c+ CLOSE c c/end-exec c return itemDs P E Thanks, Mark Mark Walter Sr. Programmer/Analyst Hanover Wire Cloth a div of CCX, Inc. mwalter@xxxxxxxxxxxxxxx http://www.hanoverwire.com 717.637.3795 Ext.3040 /"\ \ / X / \ _______________________________________________ This is the RPG programming on the AS400 / iSeries (RPG400-L) mailing list To post a message email: RPG400-L@xxxxxxxxxxxx To subscribe, unsubscribe, or change list options, visit: http://lists.midrange.com/mailman/listinfo/rpg400-l or email: RPG400-L-request@xxxxxxxxxxxx Before posting, please take a moment to review the archives at http://archive.midrange.com/rpg400-l. _______________________________________________ This is the RPG programming on the AS400 / iSeries (RPG400-L) mailing list To post a message email: RPG400-L@xxxxxxxxxxxx To subscribe, unsubscribe, or change list options, visit: http://lists.midrange.com/mailman/listinfo/rpg400-l or email: RPG400-L-request@xxxxxxxxxxxx Before posting, please take a moment to review the archives at http://archive.midrange.com/rpg400-l.
***************************************************************** compile with option: Delay PREPARE . . . . . . . . . DLYPRP *yes ***************************************************************** Here's the sql statement before it's executed: > EVAL sql_statement SQL_STATEMENT = ....5...10...15...20...25...30...35...40...45...50...55...60 1 'select * from ediinvl5 where insol in ( 'H449 ', 'H440 ', 'H' 61 '436 ' ) and indiv in ( '3T', '1E', '1C' ) and insea in ( 'H'' 121 ' ) ' ***************************************************************** * get edi inventory data d #getInventory pr * get edi sales data d #getSales pr * for sql statements d wrkediinv e ds extname( EDIINVL5 ) d wrkedisls e ds extname( EDISLSL5 ) d alist ds d pstr 100 d pwedt1 8 0 d pwedt2 8 0 d pDivisions 10a d pSeasons 5a d alist2 ds d store# 1 100 dim( 20 ) inz( *hival ) d descend d division 117 126 dim( 5 ) inz( *hival ) d descend d season 127 131 dim( 5 ) inz( *hival ) d descend d apos c const( X'7D' ) d comma c const( ',' ) d i s 5i 0 d nbrDivisions s 5i 0 d nbrSeasons s 5i 0 d nbrStores s 5i 0 d sql_statement s 1024a varying d begin s d d d s 7s 0 d end s d d hlddiv s 2a d hlddpt s 4a d hldsol s 4a d invend s 8s 0 d kendt s 6s 0 d kendt@ s 2s 0 d myDate s d d nbrTimes s 7s 0 d runtim s 6s 0 d user s 10a d wkdpt s 4a d wkpf1 s 10a d wkpf2 s 10a d wkpf3 s 10a d wkpf4 s 10a d wkpf5 s 10a ********************************************************************** * mainline logic * ********************************************************************** * check sales c callp #getSales * check inventory c callp #getInventory /eject ********************************************************************** * Procedure: #getInventory * * Useage: * ********************************************************************** p #getInventory b d #getInventory pi /free // start to build the sql statement sql_statement = 'select * from ediinvl5'; // if store numbers are passed build selection statement nbrStores = %lookup( *blanks : store# ) - 1; if nbrStores > 0; sql_statement = sql_statement + ' where insol in ('; for i = 1 to nbrStores; if i > 1; sql_statement = sql_statement + comma; endif; sql_statement = sql_statement + ' ' + apos + store#(i) + apos; endfor; sql_statement = sql_statement + ' )'; endif; // week ending date range if nbrStores = 0; sql_statement = sql_statement + ' where inend between ' + %editc( pwedt1 : 'X' ) + ' and ' + %editc( pwedt2 : 'X' ); else; sql_statement = sql_statement + ' and inend between ' + %editc( pwedt1 : 'X' ) + ' and ' + %editc( pwedt2 : 'X' ); endif; // if divisions are passed add to selection statement nbrDivisions = %lookup( *blanks : division ) - 1; if nbrDivisions > 0; sql_statement = sql_statement + ' and indiv in ('; for i = 1 to nbrDivisions; if i > 1; sql_statement = sql_statement + comma; endif; sql_statement = sql_statement + ' ' + apos + division(i) + apos; endfor; sql_statement = sql_statement + ' )'; endif; // if seasons are passed add to selection statement nbrSeasons = %lookup( *blanks : season ) - 1; if nbrSeasons > 0; sql_statement = sql_statement + ' and insea in ('; for i = 1 to nbrSeasons; if i > 1; sql_statement = sql_statement + comma; endif; sql_statement = sql_statement + ' ' + apos + season(i) + apos; endfor; sql_statement = sql_statement + ' )'; endif; /end-free * prepare sql statement c/exec sql c+ prepare sql from :sql_statement c/end-exec * declare cursor c/exec sql c+ declare c1 cursor for sql c/end-exec * open cursor c/exec sql c+ open c1 c/end-exec * fetch cursor c/exec sql c+ fetch c1 into :wrkediinv c/end-exec /free dow ( sqlcod >= 0 ) and ( sqlcod <> 100 ); chain deptKey2 CHKDPTWF; if %found( CHKDPTWF ); cdwinv = 'X'; cdwict = cdwict + 1; update DPTREC; else; cdwsol = insol; cdwdiv = indiv; cdwdpt = indpt; cdwsls = *blanks; cdword = *blanks; cdwinv = 'X'; cdwsct = 0; cdwict = 1; write DPTREC; endif; /end-free * fetch cursor c/exec sql c+ fetch next from c1 into :wrkediinv c/end-exec /free enddo; /end-free * close cursor c/exec sql c+ close c1 c/end-exec p #getInventory e /eject ********************************************************************** * Procedure: #getSales * * Useage: * ********************************************************************** p #getSales b d #getSales pi /free // start to build the sql statement sql_statement = 'select * from edislsl5'; // if store numbers are passed build selection statement nbrStores = %lookup( *blanks : store# ) - 1; if nbrStores > 0; sql_statement = sql_statement + ' where wksol in ('; for i = 1 to nbrStores; if i > 1; sql_statement = sql_statement + comma; endif; sql_statement = sql_statement + ' ' + apos + store#(i) + apos; endfor; sql_statement = sql_statement + ' )'; endif; // week ending date range if nbrStores = 0; sql_statement = sql_statement + ' where wkend between ' + %subst( %editc( pwedt1 : 'X' ) : 3 : 6 ) + ' and ' + %subst( %editc( pwedt2 : 'X' ) : 3 : 6 ); else; sql_statement = sql_statement + ' and wkend between ' + %subst( %editc( pwedt1 : 'X' ) : 3 : 6 ) + ' and ' + %subst( %editc( pwedt2 : 'X' ) : 3 : 6 ); endif; // if divisions are passed add to selection statement nbrDivisions = %lookup( *blanks : division ) - 1; if nbrDivisions > 0; sql_statement = sql_statement + ' and wkdiv in ('; for i = 1 to nbrDivisions; if i > 1; sql_statement = sql_statement + comma; endif; sql_statement = sql_statement + ' ' + apos + division(i) + apos; endfor; sql_statement = sql_statement + ' )'; endif; // if seasons are passed add to selection statement nbrSeasons = %lookup( *blanks : season ) - 1; if nbrSeasons > 0; sql_statement = sql_statement + ' and wksea in ('; for i = 1 to nbrSeasons; if i > 1; sql_statement = sql_statement + comma; endif; sql_statement = sql_statement + ' ' + apos + season(i) + apos; endfor; sql_statement = sql_statement + ' )'; endif; /end-free * prepare sql statement c/exec sql c+ prepare sql2 from :sql_statement c/end-exec * declare cursor c/exec sql c+ declare c2 cursor for sql2 c/end-exec * open cursor c/exec sql c+ open c2 c/end-exec * fetch cursor c/exec sql c+ fetch c2 into :wrkedisls c/end-exec /free dow ( sqlcod >= 0 ) and ( sqlcod <> 100 ); wkdpt = %subst( alphf1 : 1 : 4 ); chain deptKey1 CHKDPTWF; if %found( CHKDPTWF ); cdwsls = 'X'; cdwsct = cdwsct + 1; update DPTREC; else; cdwsol = wksol; cdwdiv = wkdiv; cdwdpt = wkdpt; cdwsls = 'X'; cdwinv = *blanks; cdword = *blanks; cdwsct = 1; cdwict = 0; write DPTREC; endif; /end-free * fetch cursor c/exec sql c+ fetch next from c2 into :wrkedisls c/end-exec /free enddo; /end-free * close cursor c/exec sql c+ close c2 c/end-exec p #getSales e
As an Amazon Associate we earn from qualifying purchases.
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.