×
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.
You're right. The ROWNUMBER() OVER() strategy won't work the query
specifies:
lateral correlation,
a sort sequence,
an operation that requires CCSID conversion,
a LOWER, TRANSLATE, or UPPER scalar function,
a UTF-8 or UTF-16 argument in a CHARACTER_LENGTH, POSITION, or SUBSTRING
scalar function,
a table function,
a distributed table,
a table with a read trigger,
a table referenced directly or indirectly in the fullselect must not be
a DDS-created logical file, or
a logical file built over multiple physical file members.
I'm working on an alternative method of scrolling that uses scrollable
cursors on a result set. I'll post it as soon as I have a chance to
complete it.
Kelly
-----Original Message-----
From: web400-bounces@xxxxxxxxxxxx [mailto:web400-bounces@xxxxxxxxxxxx]
On Behalf Of Peter Connell
Sent: Friday, December 04, 2009 3:43 AM
To: 'Web Enabling the AS400 / iSeries'
Subject: Re: [WEB400] Pagination with PHP and DB2 (simple working
example)
Oh rats.
I've created a new QAQQINI file with IGNORE_DERIVED_INDEX set to *NO.
But so ROWNMUMBER() OVER() still fails because of "An OLAP function is
not supported for this query".
My files must have triggers which appears to stop SQL using SQE, which
is necessary for the function to work.
Works fine if I remove the trigger but they are essential.
Peter
-----Original Message-----
From: web400-bounces@xxxxxxxxxxxx [mailto:web400-bounces@xxxxxxxxxxxx]
On Behalf Of Peter Connell
Sent: Friday, 4 December 2009 6:00 p.m.
To: 'Web Enabling the AS400 / iSeries'
Subject: Re: [WEB400] Pagination with PHP and DB2 (simple working
example)
Kelly,
That is just so clever I could cry.
Peter
-----Original Message-----
From: web400-bounces@xxxxxxxxxxxx [mailto:web400-bounces@xxxxxxxxxxxx]
On Behalf Of Kelly Cookson
Sent: Friday, 4 December 2009 5:04 p.m.
To: Web Enabling the AS400 / iSeries
Subject: [WEB400] Pagination with PHP and DB2 (simple working example)
This is certainly not the only way to paginate with DB2. I just thought
it might be useful to have a working example in the WEB400 archive.
The script assumes a DB2 file called MYLIB/MYEOP. The MYEOP file
contains four fields: EOPYEAR, EOPPRD, EOPBEGDT, EOPCLSDT.
EOPYEAR = year
EOPPRD = period
EOPBEGDT = begin date
EOPCLSDT = close date
The file holds the begin and close dates for each business period of
every year. I want to scroll back and forth through the file, seeing the
information for one year at a time. (We happen to have 13 business
periods in each year. So I want to see 13 records at a time.).
The script uses a nested SELECT to accomplish the scrolling:
"SELECT * FROM
(SELECT A.EOPYEAR, A.EOPPRD, A.EOPBEGDT, A.EOPCLSDT, ROWNUMBER()
OVER() AS RN
FROM MYLIB.MYEOP A)
X WHERE X.RN BETWEEN $rn AND $limit";
The inner SELECT retrieves all the records from the MYEOP file and adds
a new "row number field" using the ROWNUMBER() OVER() option. The outer
SELECT retrieves only the records with the desired range of row numbers.
The variable $rn contains the first row number. The variable $limit
contains the last row number.
The script also contains two forms. The form buttons let the user post
requests to scroll forward to the "next" records or backward to the
"previous" records. The session variable $_SESSION["rn"] stores the row
number across scrolling requests.
The script is listed in full below. Hope it helps.
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.