Does the trigger program processing have to occur as part of the OETITLP
I/O processing ? If it is an AFTER trigger event, that is aiming to
perform some extra functionality, but this extra functionality doesn't
really need to occur as part of the original I/O processing, it may be
worth considering the following: 

Have a new trigger program that merely write the trigger information to
a data queue. Convert the current trigger program into a never ending
batch program that is driven by the entries appearing on the data queue.
If the data queue entry cannot be processed due to record locks etc., it
is merely placed back onto the data queue so that it will be reprocessed
at a later time.



-----Original Message-----
From: rpg400-l-bounces@xxxxxxxxxxxx
[mailto:rpg400-l-bounces@xxxxxxxxxxxx] On Behalf Of Turnidge, Dave
Sent: 08 March 2007 16:00
To: RPG programming on the AS400 / iSeries
Subject: RE: Triggers 101

CPF5032    Sender copy             30   03/06/07  10:41:06.842288
QDBSIGEX     QSYS        01D6     QDBSIGEX    QSYS        01D6 
                                     Message . . . . :   Record 26697
member OESECTL already locked to this job.                  
                                     Cause . . . . . :   The record in
record format OESECR01 member number 1 of                  
                                       file OESECTL in library NATLIB is
already locked to this job. Recovery  . .                
                                       . :   The Display Job (DSPJOB)
command can be used to display the record                   
                                       locks held by the job.  Wait
until record number 26697 in member OESECTL                   
                                       file OESECTL in library NATLIB
becomes available.  Then try your request                   
                                       again. If no menus or commands
are available for you to release the lock on                
                                       the record, report the problem
(ANZPRB command). The error code is 1. If the               
                                       error code is 1, then this error
occurred in a trigger program. If the error               
                                       code is 2, then this error did
not occur in a trigger program. If the error                
                                       code is 3, then the record was
locked to another thread within this job.                   
                                       Possible choices for replying to
message . . . . . . . . . . . . . . . :   C               
                                       -- The request is canceled. I --
The request is ignored. Technical                         
                                       description . . . . . . . . :
Message CPF5032 is sent whenever an attempt                
                                       is made by a job to get a record
for update, but the record has already been               
                                       locked to the same job by a
previous get for update.  This lock will not be                
                                       released until the record is
updated, and the update option is released, the                
                                       code is 3, then the record was
locked to another thread within this job.                    
                                       Possible choices for replying to
message . . . . . . . . . . . . . . . :   C                
                                       -- The request is canceled. I --
The request is ignored. Technical                          
                                       description . . . . . . . . :
Message CPF5032 is sent whenever an attempt                 
                                       is made by a job to get a record
for update, but the record has already been                
                                       locked to the same job by a
previous get for update.  This lock will not be                 
                                       released until the record is
updated, and the update option is released, the                
                                       record is deleted, or the lock is
released with a release instruction.  If                  
                                       these menus or commands are not
available to you, there is no recovery.            
         
-----Original Message-----
From: rpg400-l-bounces@xxxxxxxxxxxx
[mailto:rpg400-l-bounces@xxxxxxxxxxxx] On Behalf Of McGovern, Sean
Sent: Thursday, March 08, 2007 9:32 AM
To: RPG programming on the AS400 / iSeries
Subject: RE: Triggers 101

What error are you receiving in the joblog ?

 

-----Original Message-----
From: rpg400-l-bounces@xxxxxxxxxxxx
[mailto:rpg400-l-bounces@xxxxxxxxxxxx] On Behalf Of Turnidge, Dave
Sent: 08 March 2007 15:15
To: RPG programming on the AS400 / iSeries
Subject: Triggers 101

I am attempting to get our triggers under control and have run into what
I *think* is a problem. It has to do with record locks, and the
discussion we had recently which also included a record lock discussion,
didn't seem to answer my question.

We have an order entry program that updates/adds to file OETITLP. This
program ALSO updates a file OESECTP. OETITLP has a trigger attached that
ALSO updates OESECTP. I believe this is causing a lock issue when the
trigger attempts to update the SAME record in OESECTP that is updated by
the program.

It seems to be that a trigger should not be updating a file that is
being updated by a program that triggers the trigger. Or, maybe, the
trigger needs to be smarter and not run when the trigger is triggered by
said program.

Is there a SOP for this?

Thank you,

Dave
642-371-1163


--
This is the RPG programming on the AS400 / iSeries (RPG400-L) mailing
list To post a message email: RPG400-L@xxxxxxxxxxxx To subscribe,
unsubscribe, or change list options,
visit: http://lists.midrange.com/mailman/listinfo/rpg400-l
or email: RPG400-L-request@xxxxxxxxxxxx
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 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.