|
Scott,
-mark
At 2/28/05 03:47 PM, you wrote: Is there a downside to using *CALLER for the activation group on triggers?
That sounds like it would "adapt" better to calls from various sources.
Unless I'm confused, triggers are always called by the database manager in the operating system. Not much to "adapt" to, since it's always the same program. I don't see why you'd want your trigger to be run in the same activation group as the database manager -- particularly since it's probably the default activation group (Though, I haven't tested that theory...).
Putting it in a named group gives me more control. I like to activate my triggers once, keep the files open, etc, so that they can be called over and over with the smallest possible performance penalty.
Putting them in a named activation group makes it possible for them to be cleaned up simply be deleting the activation group. I have a lot of utility service programs with very useful routines that I tend to call from all of my programs, including triggers. Because I used a named activation group for the trigger, and the utilities are compiled with *CALLER, I can reclaim the activation group and unload all of the utilities, and close all of the files, and free up all of the resources that they use with one simple command.
This is particularly helpful when I'm debugging my programs.
But, it's also occasionally useful for other things. For example, we have a daily batch job that rebuilds some of our files. Before that can be run, you have to get each user who uses those particular files to close them.
When my triggers that use them are compiled in a named activation group, I can have a break-handling program reclaim that actgrp, thus closign the files. Or, I can have a menu option that a user can run that does it. Or even have it be reclaimed by a CL program just before returning to the menu.
That allows me to keep a trigger loaded in memory, and only reclaim it when I need to.
If my triggers ran in the default activation group, I'd either have to close the files with each call to the trigger (awful performance!) or I'd have to make the user completely sign-off to close the files.
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.