×
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.
FETCH FIRST N ROWS is only supported in the outer level of a query and in a
derived table, not in a subquery (which is where you are trying to use it).
What you can do is push the clause one level deeper into a derived table.
UPDATE FILEA F
SET FIELDA = 'N' where RRN(F) in
( SELECT R FROM
(
SELECT RRN(F) R from FILEA F where FIELDA='X'
Fetch first 1500 rows only
) X
)
This has been supported since V5R2.
Sue Romano
i5/OS SQL parser
----- Original Message -----
From: "Alan Shore" <AlanShore@xxxxxxxx>
To: "RPG programming on the AS400 / iSeries" <rpg400-l@xxxxxxxxxxxx>
Sent: Wednesday, December 05, 2007 9:00 AM
Subject: RE: Update the first 1500 records that need updating
I finally got around to testing the SQL statement that Steve suggested
The subselect
SELECT RRN(F) from FILEA F where FIELDA='X'
Fetch first 1500 rows only
worked fine on its own
but when I attempted to run the whole thing, like Robert, I received
Keyword FETCH not expected. Valid tokens: ) UNION EXCEPT.
I'll probably have to write a quick RPG program instead.
Thanks to everyone who replied to my request
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.