Solved

Validating multiple fields prior to database record insertion/update

Posted on 2008-10-27
14
189 Views
Last Modified: 2011-10-19
I've got 3 fields on a form,  start time, end time and duration; pretty simple and I'm trying to validate them.  Start time and end time are optional if duration is provided.  Likewise if start and end times are provided, duration will be calculated automatically if not provided.  If all 3 are present, duration must be the difference between the start and end times.  Finally, start time without end time is prohibited and visa-versa.  

I was attempting to validate this in the Before_Update event but since I have all the validation code present, checking all the conditions, when entering a new db record, I'm getting lots of error messages informing me of conditions I know aren't correct because I haven't entered the data yet.   What I seem to need is an event that gets fired just before the record is to be written so I can validate all fields together not each individually since there is a dependency.  How can this validation be done without the use of an Update/Insert button type of logic?
0
Comment
Question by:ejefferson213
  • 8
  • 6
14 Comments
 
LVL 119

Expert Comment

by:Rey Obrero
Comment Utility
which before update event are you using? for every field?

use the form's beforeupdate event to validate the values.
0
 

Author Comment

by:ejefferson213
Comment Utility
Thank you for your prompt reply.  Actually, I have both but I could adjust that I suppose.  However, reading some documentation, it appears that after a control field's BeforeUpdate event is handled, the form's BeforeUpdate event is fired.  So even if I remove the field's BeforeUpdate event, the form's BeforeUpdate event will fire (prematurely in my case) resulting in my same issue. I'm back to needing something to trigger after all fields have been entered so I can collectively validate them.
0
 
LVL 119

Expert Comment

by:Rey Obrero
Comment Utility
did you try it?
the form's before update should fire when you moved to another record in editing record or adding new records.
0
 

Author Comment

by:ejefferson213
Comment Utility
I removed the events for each of the fields leaving only the form's BeforeUpdate event and it's acting as before.  If I try entering a start time and tab to the end time field, my validation rules are firing stating that an end time is needed if a start time is provided.  It looks like I'll need to provide an update button for each line of my datasheet (YUK!) unless there are other alternatives.
0
 
LVL 119

Expert Comment

by:Rey Obrero
Comment Utility
if you are validating the fields in the form's beforeupdate event, you don't need the validation rules in your controls and fields.
0
 

Author Comment

by:ejefferson213
Comment Utility
I've removed the events for the controls and eliminated the validation in the table fields.  Therefore, the only thing left is the BeforeUpdate event on the form.  It's weird, it's validating the fields when moving between the fields on the form rather than at the end when moving off of this new entry. I've downgraded my validation so I'm "by" the problem but I'd like to know how to resolve this more fully.  Thanks again.
0
 
LVL 119

Expert Comment

by:Rey Obrero
Comment Utility
how about the form's controls validation ?
0
How your wiki can always stay up-to-date

Quip doubles as a “living” wiki and a project management tool that evolves with your organization. As you finish projects in Quip, the work remains, easily accessible to all team members, new and old.
- Increase transparency
- Onboard new hires faster
- Access from mobile/offline

 

Author Comment

by:ejefferson213
Comment Utility
This form is actually a subform and it has a BeforeUpdate event which is the only place where the validation is taking place.  No validation is being done on the individual fields or in the main form.  Hopefully that answers your question.
0
 
LVL 119

Expert Comment

by:Rey Obrero
Comment Utility
did you open the form in design view, select the control, hit f4, click the Data tab, look in the property  Validation Rule, Validation Text
0
 

Author Comment

by:ejefferson213
Comment Utility
Did as you said and no field on the form has a validation rule or validation text.
0
 
LVL 119

Accepted Solution

by:
Rey Obrero earned 500 total points
Comment Utility
can you upload your db? check Attach File below. just remove sensitive data
0
 

Author Comment

by:ejefferson213
Comment Utility
To use this app:
  1).  Open database
  2). Open form TimeSheetUseridPassword
  3). In Name box, select EJ
  4). Enter the password abc and click on submit
  5).  Click on Add/Change Times
  6).  Try entering a new time sheet

Thank you.
DebuggingTimeSheets.mdb
0
 

Author Comment

by:ejefferson213
Comment Utility
BTW, when using the form to enter a date, the field has a Format of Short Data and an input mask of 09/09/0099;0;_    When the cursor is placed in that field to enter information and valid numbers entered, it immediately (not when moving to another field) says: "The value you entered isn't appropriate for the input mask '09/09/0099;0;_' specified for this field.   Do you have any idea why that would be?  The digits are numeric and it ultimately takes it anyway. (I'm sure you'll experience the same thing.)  
0
 

Author Closing Comment

by:ejefferson213
Comment Utility
After recreating the form, the problem disappeared.  Thanks for working with me to attempt a fix!!!!
0

Featured Post

Threat Intelligence Starter Resources

Integrating threat intelligence can be challenging, and not all companies are ready. These resources can help you build awareness and prepare for defense.

Join & Write a Comment

In Debugging – Part 1, you learned the basics of the debugging process. You learned how to avoid bugs, as well as how to utilize the Immediate window in the debugging process. This article takes things to the next level by showing you how you can us…
I originally created this report in Crystal Reports 2008 where there is an option to underlay sections. I initially came across the problem in Access Reports where I was unable to run my border lines down through the entire page as I was using the P…
Familiarize people with the process of utilizing SQL Server functions from within Microsoft Access. Microsoft Access is a very powerful client/server development tool. One of the SQL Server objects that you can interact with from within Microsoft Ac…
What’s inside an Access Desktop Database. Will look at the basic interface, Navigation Pane (Database Container), Tables, Queries, Forms, Report, Macro’s, and VBA code.

772 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question

Need Help in Real-Time?

Connect with top rated Experts

11 Experts available now in Live!

Get 1:1 Help Now