Hey Rick,

This is the optimum solution I believe.

FOUND = *OFF
SELECT '1' INTO :FOUND
FROM FILE
WHERE FIELD LIKE '___abc___'
FETCH FIRST 1 ROWS ONLY

Mark

> ----- Message from "rick baird" <rick.baird@xxxxxxxxx> on Tue, 18 
> Apr 2006 10:56:16 -0400 -----
> 
> To:
> 
> "Midrange Systems Technical Discussion" <midrange-l@xxxxxxxxxxxx>, 
> "RPG programming on the AS400 / iSeries" <rpg400-l@xxxxxxxxxxxx>
> 
> Subject:
> 
> SQL to only check for existence:
> 
> hey all,
> 
> Is there a way to run an SQL statement that doesn't (necessarily)
> return anything, but only checks for the existence of one or more
> records based on a where statement - similar to a SETLL and %found?
> 
> I've got a rather complicated SQL statement using:
> LIKE '___abc___'    or it could be:
> LIKE ______xyz'
> 
> - over a very large file, and I'm having performance issues.
> 
> I don't want to do a count(), because I don't care how many, only that
> at least one exists.   with count, it would have to read through the
> entire file to determine it.
> 
> I also tried just doing a select - optimize for 1 row and a single
> fetch, but that seemed to take forever too.  It appears as if it is
> searching the entire file, instead of stopping at the first one.
> 
> help!
> 
> Rick

As an Amazon Associate we earn from qualifying purchases.

This thread ...

Follow-Ups:

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.