|
On Wed, 10 May 2023 at 18:40, Alan Cassidy <cfuture@xxxxxxxxxxx> wrote:
Thanks Buck! I've been using the DIAGNOSTIC values, but that seems a
more sure thing.
Be sure to read Charles' reply - he was much clearer than I regarding
DIAGNOSTIC values.
But wait, you need a SELECT to do the count, and you can't do it when
you open a cursor. I don't think you would run the cursor and then do
this count with the same SELECT statement, so how is this?
When I need a count before starting a processing loop, I run the
SELECT COUNT(*) INTO...first - no cursor.
Yes, this means two separate exec sql blocks.
But I very rarely need to know how many records there are _before_ I
start processing them. (Reeve apparently does, thus my reply).
It's more typical for me to simply process them until I get to the end
of the subfile or end of the result set. If I need a count of those I
FETCHed or UPDATEd, I use SQLER3. That's especially useful if I'm
FETCHing FOR n ROWS.
The SQL cursors I use take a long time. It's probably quicker for the
second SELECT, but I don't think that much.
The optimiser can be a pleasant surprise that way. SELECT COUNT(*)
always seems to run faster than selecting a bunch of columns over a
bunch of rows.
In general, if I have slow performing cursors, I look at creating some
new indexes as a first step.
--buck
--
This is the RPG programming on IBM i (RPG400-L) mailing list
To post a message email: RPG400-L@xxxxxxxxxxxxxxxxxx
To subscribe, unsubscribe, or change list options,
visit: https://lists.midrange.com/mailman/listinfo/rpg400-l
or email: RPG400-L-request@xxxxxxxxxxxxxxxxxx
Before posting, please take a moment to review the archives
at https://archive.midrange.com/rpg400-l.
Please contact support@xxxxxxxxxxxxxxxxxxxx for any subscription related
questions.
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.