Hi Rob,

sorry, but
SELECT ... INTO ...

is not supported by dynamic SQL!

The following static SQL-Statement will do the job.
C/EXEC SQL  Select cnum, lname, fname
C+            into :HostNum, :HostLName, :HostFName
C+            from MyTable
C+            where cnum = :HostVar
C+ Fetch first row only
C/END-EXEC

And why dynamic when static is possible?
Just a few comments:
1. For static SQL access plans are stored in the program object and can be
used and validated each time the SQL-Statement gets executed. Even different
access plans for a single statement can be stored and be validated. For
dynamic SQL access plans are built, but not stored and must be rebuilt each
time the prepare statement gets executed.
2. That's why PRTSQLINF can only be used for static SQL-Statements.
3. The run-time overhead is greater for statements processed using dynamic
SQL than for static SQL statements. The additional process is similar to
that required for syntax checking, precompiling, binding, and then running a
program, instead of only running it. Therefore, only applications requiring
the flexibility of dynamic SQL should use it.

In most cases dynamic SQL can be replaced with static SQL. It's only
necessary when tables or schemas must be used as variables or different
select fields are needed.

Mit freundlichen Gru?en / Best regards

Birgitta

"Shoot for the moon, even if you miss, you'll land among the stars."
(Les Brown)

-----Ursprungliche Nachricht-----
Von: rpg400-l-bounces@xxxxxxxxxxxx
[mailto:rpg400-l-bounces@xxxxxxxxxxxx]Im Auftrag von rob@xxxxxxxxx
Gesendet: Mittwoch, 15. Marz 2006 18:02
An: RPG programming on the AS400 / iSeries
Betreff: Re: Simple SQL in RPG question.


1 - You do not need to use a cursor on a single row fetch!  You can do a
direct 'select into' instead of a declare, open, fetch, close.
2 - I already gave you an example of using "parameter markers" in that
code sample I gave you.  Remember the
       stmt1='select cnum, lname, fname ' +
             'into :cnum, :lname, :fname ' +
             'from customer where cnum=?';
      /end-free
     C/EXEC SQL
     C+ Prepare S1 from :stmt1
     C/END-EXEC
...
     C/EXEC SQL
     C+ Execute S1 using :ThisCust
     C/END-EXEC

See the 'where cnum=?'?  ThisCust would be what was passed into the
program, or prompted from the screen.


Rob Berendt
--
Group Dekko Services, LLC
Dept 01.073
PO Box 2000
Dock 108
6928N 400E
Kendallville, IN 46755
http://www.dekko.com





"Mike Troxclaire" <mike_troxclaire@xxxxxxxxxxx>
Sent by: rpg400-l-bounces@xxxxxxxxxxxx
03/15/2006 11:30 AM
Please respond to
RPG programming on the AS400 / iSeries <rpg400-l@xxxxxxxxxxxx>


To
rpg400-l@xxxxxxxxxxxx
cc

Subject
Simple SQL in RPG question.






Hello All;

With all your help and input, I am able to run a SQL embedded RPG program
and produce a report. Now, I want the user to be able to go to the green
screen and say CALL MYPROG('CSTNUM') and the results should be displayed
on
the screen(not create a report). Right now, I have hardcoded the customer
number. The SQL statement is very complicated one so for simplicity I am
just using a small one over here. I will further improve on it using a
DSPF
but for now I just want to call my program and pass the customer number as
a
parameter. Here is what I coded till now. Please overlook the coding
inadequacies of a novice programmer. Any help in this matter will be much
appreciated.

****************************************************************************
**

     FQSYSPRT   O    F  132        PRINTER


     D  CSTNUM         S             10
     D  CSNAME         S             30
     D  CSADD1         S             30
     D  COUNT          S              7  0

     C                   EXSR      PROCESS
     C                   EXSR      ENDPGM


     C     PROCESS       BEGSR
     C                   EXSR      WORK01
     C                   ENDSR


     C     WORK01        BEGSR
     C/EXEC SQL
     C+ DECLARE MYCUR CURSOR FOR SELECT CSTNUM, CSNAME,
     C+ CSADD1 FROM LIBRARY1/CSTMST WHERE CSTNUM = '   XXXXXXX'
     C/END-EXEC

     C/EXEC SQL
     C+ OPEN MYCUR
     C/END-EXEC


     C                   EXCEPT    HEAD1
     C                   EXSR      @@FETCH
     C                   DOW       SQLCOD = 0
     C                   EXCEPT    DET1
     C                   EVAL      COUNT = COUNT + 1
     C                   EXSR      @@FETCH
     C                   ENDDO


     C/EXEC SQL
     C+ CLOSE MYCUR
     C/END-EXEC
     C                   EXCEPT    DET2

     C                   ENDSR



     C     @@FETCH       BEGSR
     C/EXEC SQL
     C+ FETCH NEXT FROM MYCUR INTO :CSTNUM, :CSNAME, :CSADD1
     C/END-EXEC
     C                   ENDSR

     C     ENDPGM        BEGSR
     C                   EVAL      *INLR = *ON
     C                   ENDSR


     OQSYSPRT   E            HEAD1          1
     O                                           +0 'CSTNUM'
     O                                           +1 'CSNAME'
     O                                           +1 'CSADD1'
     O          E            DET1           1
     O                       CSTNUM              +0
     O                       CSNAME              +2
     O                       CSADD1              +2
     O          E            DET2           1
     O                       COUNT         4     +0

****************************************************************************
**

Cheers,

Mike.

_________________________________________________________________
Express yourself instantly with MSN Messenger! Download today - it's FREE!

http://messenger.msn.click-url.com/go/onm00200471ave/direct/01/

--
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.




As an Amazon Associate we earn from qualifying purchases.

This thread ...

Follow-Ups:
Replies:

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.