× The internal search function is temporarily non-functional. The current search engine is no longer viable and we are researching alternatives.
As a stop gap measure, we are using Google's custom search engine service.
If you know of an easy to use, open source, search engine ... please contact support@midrange.com.



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

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