|
I don't anything "technically" wrong... I would suggest though that you
change it from a prepared statement to a regular statement using a host
variable.
i.e.
Begsr mysr
Exec SQL
Declare C2 Cursor For
Select * from myfile
Where myfield = char(:someDateField);
Exec SQL
Open C2;
If SqlCod < 0;
//Treat error
EndIf;
DoU SqlCod <> 0;
Exec SQL
Fetch Next from C2 Into :MyFile_DS;
If SqlCod < 0;
Leave;
Endif;
...
Leave;
EndDo;
Exec SQL
Close C2;
EndSr;
Doing it this way will prevent the prepare from occurring over and over
again.
To answer the other question, a chain wouldn't work because the
original programmer must have thought that he could get multiple
records from this file based on the where clause. That being said, a
regular I/O setll and reade would have been just as good.
Something else to keep in mind about SQL. If you write SQL code
correctly, you wouldn't have to make compile changes to programs using
SQL. However, since the programmer did a "select * " into the DSPECS
of the formatted like the external file, this program would need to be
recompiled because the DSPECS would have changed and you would likely
get sqlcod other than 0. Try to convince the programmer to select only
the fields they need. This will also help with the data retrieval in
the fetch statement.
-----Original Message-----
From: rpg400-l-bounces@xxxxxxxxxxxx [mailto:rpg400-l-
bounces@xxxxxxxxxxxx] On Behalf Of David FOXWELL
Sent: Tuesday, October 12, 2010 6:50 AM
To: RPG programming on the IBM i / System i
Subject: RE: Astonished by embedded sql
-----Message d'origine-----
De : rpg400-l-bounces@xxxxxxxxxxxx
[mailto:rpg400-l-bounces@xxxxxxxxxxxx] De la part de Dennis Lovelady
It seems to me that this is the equivalent of openingmyfile for each
subroutine call, reading every record in the file then closing the
file again.
Yes, that's right.
Although I'm not sure about the reading. Is the whole fileread at the
open cursor statement?
No, but it is read in its entirety at the DoU loop. (FETCH does the
lifting.)
Thanks, Dennis. But if the FETCH was executed more than once, it
wouldn't be read in its entirety a second time, would it?
By the way, I didn't think FETCH into *qualified* DS did
quite what we would hope. Perhaps I am mistaken on that.
I didn't even notice. That's going too far! How do you suggest breaking
all this to the person who wrote it?
--
This is the RPG programming on the IBM i / System i (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 IBM i / System i (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 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.