|
thanks for your valuable feedback, Ken. Now, in my case, the file being multi format logical file (of 6 physical files), 20 records of which file will be brought into memory ... is it all the six files or ??? forgot to mention in my earlier mail that, apart from select criteria for PNO range (so that multiple jobs can be submitted in parallel), ther is also another selection criteria which excludes some of the records from the file .... hence not all records of primary file are being processed (as rightly questioned by Martin Booth earlier "You are processing 100% of them anyway, right? ") really breaking my head to get performance improvement in this program. Ken Sims <mr2087@ke9nr.net>@midrange.com on 12/26/2002 05:57:36 AM Please respond to rpg400-l@midrange.com Sent by: rpg400-l-admin@midrange.com To: rpg400-l@midrange.com cc: Subject: Re: NBRRCDS and BLOCK(*YES) Hi Uma - >8) Now my worry is, where ever I refer to NBRRCDS details it mentions that >" if the file is processed by a keyed order, then the physical order of >data should be same as the keyed order else NBRRCDS will worse the >performance" What NBRRCDS does is tell the operating system how many records to bring from the disk at one time. This is not the same as blocking for two reasons: 1. Blocking involves a private memory area specific to the open data path being used (and therefore cannot be used with update files, otherwise every record in the block would have to be locked); NBRRCDS just pages in the records in. Every job that wants any of these records benefits by this. If updating, only the record actually being read is locked. Records could be paged back out before the program actually reads them. 2. Blocking is done is in sequence that the records are being accessed: keyed or arrival. NBRRCDS is always done in arrival sequence. That's why the warning. For example, let's say that NBRRCDS is 20. You are reading by key. The first key happens to point to record 1. Since NBRRCDS is 20, the read actually brings records 1-20 from the disk into memory, and puts record number 1 in the program's buffer. If the second key points to any of records 2-20, then the record is already in memory and just has to be put in the program's buffer. However if the second key happens to point to record 100, then the record brings in records 100-119 and puts record 100 in the program's buffer. IF the system has enough memory and few enough other jobs running, records 2-20 may still be hanging around in memory when the program finally reaches the key that points to one of them. If so, then NBRRCDS helped. If not, then NBRRCDS hurt because records were brought into memory unnecessarily. If reading by key, the more the arrival sequence matches the key sequence, the more help from NBRRCDS. NBRRCDS will always help with arrival sequence unless the system is so active that the records are paged back out between one read and the next. Ken http://www.ke9nr.net/ Opinions expressed are my own and do not necessarily represent the views of my employer or anyone in their right mind. _______________________________________________ This is the RPG programming on the AS400 / iSeries (RPG400-L) mailing list To post a message email: RPG400-L@midrange.com To subscribe, unsubscribe, or change list options, visit: http://lists.midrange.com/cgi-bin/listinfo/rpg400-l or email: RPG400-L-request@midrange.com Before posting, please take a moment to review the archives at http://archive.midrange.com/rpg400-l.
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.