× 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.



Thanks for taking the time to submit this DCR, Rory. It is unfortunate that the developers can't see the need. I can certainly attest to the high overhead involved in high-volume batch processing. I have had to remove it from more than one production trigger due solely to this completely unnecessary overhead.

This is long, long overdue. I don't understand why the people in the press haven't been screaming about this for the last 10 years! It's rare that I've even seen it mentioned in the many books and articles written on triggers over the years. It was such a simple thing to have included that it was obviously an oversight on the part of whoever designed the buffer in the first place, and the trouble with oversights like this is no one wants to admit to it. Its been a pain-in-our-side ever since triggers came out and there is simply no justification for not having fixed it long ago.

Hewitt, Rory wrote:

Frank,

I opened a DCR (Design Change Request) number MR082903246 in August 2003
as follows:

---------

1. Request Title:

Addition of Application Program/Library name to Trigger Buffer

2. Provide a detailed description of request (including unique usage):

When an application program updates a database file which has a trigger
attached, the trigger program is called by the database itself and is
passed a trigger buffer parameter, containing information about the type
of database update that is being attempted and also 'before' and 'after'
database record images.

One piece of important information missing from the trigger buffer is
the name of the application program/library which is attempting to
update the database. For the trigger program to manually retrieve this
information requires at least one API call and some additional
processing, which affects the performance of database processing. Since
triggers are described as having excellent performance (because they are
called directly by the database rather than by the application program
itself), it's annoying that we need to offset this by adding additional
API calls, especially as the information we need (application program
name) is available to the database when it calls the trigger program.

3. Do you have a suggested solution?

Include the application program name and library within the trigger
buffer. The trigger buffer structure includes data based on offsets
rather than at fixed positions within the structure, so there should be
no problem in adding extra information.

---------

IBM replied 8 MONTHS LATER with this: "If this were done, it could only
work for native triggers (not sql triggers), would this be acceptable?".
So I responded with:

---------

I would think so - for SQL triggers, perhaps simply filling the (new)
AppPgm field with "*SQL" and leaving the (new) AppLib field blank would
be acceptable. After all, it is currently possible to discover this
information within the trigger program by going back up the call stack -
it's simply a hassle and can hit performance, which is a problem if the
trigger is potentially being called thousands of times. Therefore users
of SQL triggers aren't completely lost - they simply won't get the
benefit of this new feature.

My more immediate concern is where within the trigger buffer this new
information could be placed - would it be placed within the variable
section and if so, how would it be located?

Is the 16-byte reserved section at offset 80 currently used, or is it
simply a spacer? If it's only a spacer, could it be changed to be a
pointer to a fixed-format control section which could contain the AppPgm
and AppLib fields (as well, possibly as other control information)? If
not, I don't see how this information could be added...

---------

I never heard anything back from them after that...

Rory



As an Amazon Associate we earn from qualifying purchases.

This thread ...

Replies:

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.