• Subject: Re: User Index APIs - where find REAL reference material?
  • From: "Simon Coulter" <shc@xxxxxxxxxxxxxxxxx>
  • Date: Sun, 01 Aug 99 18:07:51 +1000


Hello Dan,

This stuff isn't really that hard.  You do have to read a number of manuals 
because all the 
information isn't in a single place.  Read them, think about what they say, and 
practice.  
That's all.  You may find the following manuals useful:
        OS/400 Object APIs manual (for the User Index APIs of course)
        Machine Interface Functional Reference (explains how each of the MI 
instructions works 
which is helpful because the APIs are simply front-ends for the MI 
instructions.)
        C MI Library Reference (has examples of code using the APIs and MI 
instructions - in C 
but they are fairly clear examples -- C's not like Lisp or APL)

Also useful are the S/38 Functional Concepts and S/38 Functional Reference 
Manual if you can 
find them.  I think there used to be an AS/400 Functional Concepts Manual but I 
can't find a 
reference to it at the moment.

Now to your specific questions:

> Key Insertion: Whether or not the inserts to the index are by key.  The valid
> values are:
>      '0'  No insertion by key
>      '1'  Insertion by key
> 
> Is this asking whether I'll be loading the index in key sequence?  Am I
> confusing the term "insert" with "add"?  (as in "inserting" a new entry in the
> middle of the index vs. "adding" a new entry at the end of the index)

It is asking whether you will be designating part of the entry as the key used 
when inserting 
entries.  You can either treat the whole entry as a unique value or nominate a 
certain length 
from the first byte as the key.  The 'key insertion' creation attribute simply 
builds an index 
that understands the key component.  If you specify '0' you are limited to 
using an insert type 
of '1' when inserting entries with the QUSADDUI API or insinxen MI instruction. 
 If you specify 
'1' you are limited to using insert types '2' and '3'.

> Immediate Update:  Whether or not the updates to the index are written
> synchronously to auxiliary storage on each update to the index.  The valid
> values are:
>      0    No immediate update
>      1    Immediate update
>  Each update to the index is written to auxiliary storage after every insert 
>and
> remove operation.
> 
> What impact does this parameter have?  In the one application, the UI would be
> created and loaded with data.  It would not be updated, i.e., existing entries
> modified or entries added or deleted.

The impact is on performance and reliability.  If '1' is specifed then every 
entry you add to 
the index is forced to DASD therefore improving reliability (the entry won't be 
lost if the 
system fails) at the expense of performance (the DASD write is synchronous and 
your application 
waits until the write completes).  Since you seem to be loading the index from 
some external 
source (DB?) specifying '0' is probably what you require.

> Also, on the Add User Index Entries (QUSADDUI) API, it appears that you can 
>add
> up to 4095 index entries on one call.  Is this correct?  If so, would you
> typically use an array or a multiple-occurence data structure to pass the 
>data?

Yes, that is correct.  The second parameter on the API tells you how many 
entries were 
successfully added.  Since a MODS is currently implemented using contiguous 
storage it would 
work but an array is what is generally expected for fixed length entries.  If 
you are using 
variable length entries then you also must pass a structure of offsets and 
lengths used to 
parse the entry data.

> Those of you who have the answers, where did you learn this?  I certainly have
> failed to find out in the IBM softcopy manuals.

Well, my usual mantra of RTFM applies again.  The information is in the IBM 
manuals but needs 
to be nutted out.  Perhaps I find the IBM manuals easier to read than other 
people but they are 
intended for system programmer's.

Maybe I should write 'A Real Programmer's Guide to the AS/400'?  Any particular 
topics it 
should cover?

Regards,
Simon Coulter.

«»«»«»«»«»«»«»«»«»«»«»«»«»«»«»«»«»«»«»«»«»«»«»«»«»«»«»«»«»«»«»«»«»«»
«» FlyByNight Software         AS/400 Tec
ical Specialists       «»
«» Eclipse the competition - run your business on an IBM AS/400.  «»
«»                                                                «»
«» Phone: +61 3 9419 0175      Mobile: +61 0411 091 400           «»
«» Fax:   +61 3 9419 0175      mailto: shc@flybynight.com.au      «»
«»                                                                «»
«» Windoze should not be open at Warp speed.                      «»
«»«»«»«»«»«»«»«»«»«»«»«»«»«»«»«»«»«»«»«»«»«»«»«»«»«»«»«»«»«»«»«»«»«»
//--- forwarded letter -------------------------------------------------------
> Date: Wed, 28 Jul 99 17:37:20 -0400
> From: "Dan Bale" <dbale@genfast.com>
> To: MIDRANGE-L@midrange.com
> Reply-To: MIDRANGE-L@midrange.com
> Subject: User Index APIs - where find REAL reference material?

> I am trying to understand and create my own applications using user indexes, 
>but
> am relegated to using others' examples, which does not help me understand the
> intricacies of the APIs involved.

-------- Stuff deleted ------------------
> 
> TIA,
> Dan Bale
+---
| This is the Midrange System Mailing List!
| To submit a new message, send your mail to MIDRANGE-L@midrange.com.
| To subscribe to this list send email to MIDRANGE-L-SUB@midrange.com.
| To unsubscribe from this list send email to MIDRANGE-L-UNSUB@midrange.com.
| Questions should be directed to the list owner/operator: david@midrange.com
+---


As an Amazon Associate we earn from qualifying purchases.

This thread ...


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.