|
A trigger program is about as easy as it gets and allows other validity checking as well. As we move more and more to processing the data in rpg ways and in non-rpg ways we have to consider making the business rules at the data level, not the program level. Besides, wouldn't it be nice to have a shop standard that says "do not worry about timestamps and maintainence fields. Its already done" --------------------------------------------------------- Booth Martin http://www.MartinVT.com Booth@MartinVT.com --------------------------------------------------------- -------Original Message------- From: Midrange Systems Technical Discussion Date: Tuesday, January 14, 2003 09:55:33 AM To: 'Midrange Systems Technical Discussion' Subject: RE: Initializing a timestamp field when adding a record Just a quick point... d $ts S z c time $ts It's VERY easy to set the current time into a timestamp field now, so it seems you're jumping through hoops for not a lot of value. If you need to control when a timestamp is set, then avoid the "automatic" stuff. Its one of those things that some new coder will get wrong or not understand...... Eric DeLong Sally Beauty Company MIS-Project Manager (BSG) 940-898-7863 or ext. 1863 -----Original Message----- From: Reeve Fritchman [mailto:reeve@ltl400.com] Sent: Monday, January 13, 2003 10:12 PM To: 'Midrange Systems Technical Discussion' Subject: RE: Initializing a timestamp field when adding a record This explanation makes sense; unfortunately, the documentation doesn't. You don't want the system "helping" you by automatically posting values to fields you want to keep "empty" (like timestamp indicating a "last use"). A before trigger is an excellent suggestion but my requirement is simple; adding another line of code to the program is the best solution (it provides the desired result with minimal code and no confusion). Doug, thanks... -reeve -----Original Message----- From: midrange-l-bounces@midrange.com [mailto:midrange-l-bounces@midrange.com] On Behalf Of Douglas Handy Sent: Monday, January 13, 2003 10:43 PM To: Midrange Systems Technical Discussion Subject: Re: Initializing a timestamp field when adding a record Reeve, >Am I mis-reading or was it mis-written? I'm mis-tified. I believe the DFT() value, or in your case, the implied default of the current time, is only applied when using a record format excluding the field. Thus when you used a LF without the timestamp field, the PF received the current time. Similarly, if you used a SQL INSERT without naming the field, it would also receive the current time. In your second DFU (the one without the timestamp field), did you use the PF record format name? If so, that would explain the behavior. In that case you in essence named the field by virtue of it being in the format, and thus are responsible for populating the field. In RPG if you name the PF format you have the same situation -- the default does not apply anymore. If you don't want to use a LF which excludes the timestamp field, another option would be to create a *Before trigger which allows repeating changes, and modify the record buffer to include the current time (and possibly user ID, etc). Doug
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.