Thanks everyone for the response. I was over thinking, thanks Scott for pointing me in the right direction!
-----Original Message-----
From: MIDRANGE-L [mailto:midrange-l-bounces@xxxxxxxxxxxx] On Behalf Of Scott Mildenberger
Sent: Monday, December 08, 2014 12:20 PM
To: Midrange Systems Technical Discussion
Subject: RE: Dynamic SQL
But I believe you should be able to do:
Exec sql select sum(pinv) into :w1 from CMSFWRK20
where PCLS between :w2 and :w3
and PYEAR = :w4 and PPERD = :w5
Scott
-----Original Message-----
From: MIDRANGE-L [mailto:midrange-l-bounces@xxxxxxxxxxxx] On Behalf Of John R. Smith, Jr.
Sent: Monday, December 08, 2014 10:15 AM
To: 'Midrange Systems Technical Discussion'
Subject: RE: Dynamic SQL
Merging this answer with Jim's and what I can remember doing, a "select into" can't be done as an execute so you need to create a cursor and do a fetch into a variable.
-----Original Message-----
From: MIDRANGE-L [mailto:midrange-l-bounces@xxxxxxxxxxxx] On Behalf Of Alan Campin
Sent: Monday, December 08, 2014 11:46 AM
To: Midrange Systems Technical Discussion
Subject: Re: Dynamic SQL
From the manual on SELECT INTO.
This statement can only be embedded in an application program. It is an executable statement that cannot be dynamically prepared. It must not be specified in REXX.
I think you might need a space before and in the 3rd line.
On Mon, Dec 8, 2014 at 9:26 AM, Billy Waters <bwaters@xxxxxxxxxxxxxxxxxx>
wrote:
My first attempt at using dynamic SQL. Any help would be greatly
appreciated.
w2 = 'R1';
w3 = 'R9';
w4 = 2015;
w5 = 4;
WSQL = 'select sum(pinv) into ? from CMSFWRK20 ' +
'where PCLS between ? and ? ' +
'and PYEAR = ? and PPERD = ?';
Exec Sql prepare S1 from :WSQL;
Exec SQL
execute S1 using :w1, :w2, :w3, :w4, :w5;
job log shows
call test
Token ? was not valid. Valid tokens: : <IDENTIFIER>.
Prepared statement S1 not found.
--
This is the Midrange Systems Technical Discussion (MIDRANGE-L) mailing list To post a message email: MIDRANGE-L@xxxxxxxxxxxx To subscribe, unsubscribe, or change list options,
visit:
http://lists.midrange.com/mailman/listinfo/midrange-l
or email: MIDRANGE-L-request@xxxxxxxxxxxx Before posting, please take a moment to review the archives at
http://archive.midrange.com/midrange-l.
As an Amazon Associate we earn from qualifying purchases.