Solved

Required Fields on Access Form

Posted on 2009-05-04
12
334 Views
Last Modified: 2013-11-27
I am struggling with a data entry form, I have created in Access.

There are about 10 fields on the form that are required, they range from combo boxes, text fields and memo fields. The rest is not required information. In the table i have all of the feilds marked as required. Right now the error message is pretty generic, saying "The table doesn't allow for a null value" I want the error message to tell me which feild it is not letting me submit? What is the best way to do this? Through code? In the table? How can I get this set-up?
0
Comment
Question by:SueMos
[X]
Welcome to Experts Exchange

Add your voice to the tech community where 5M+ people just like you are talking about what matters.

  • Help others & share knowledge
  • Earn cash & points
  • Learn & ask questions
  • 6
  • 2
  • 2
  • +1
12 Comments
 
LVL 75
ID: 24298559
Try this

Private Sub Form_BeforeUpdate (Cancel As Integer)

    If Nz(Me.SomeField1,"")="" Then
           Msgbox "SomeField1 is required
           Cancel = True
           Exit Sub
    End If
     
 '  same code for the other fields


End Sub

mx
0
 
LVL 16

Accepted Solution

by:
Chuck Wood earned 500 total points
ID: 24298583
You can use the OnExit event to trigger a check of the txt field (or memo field). Also you can use the same code when you click a command button.

Private Sub txtName_Exit(Cancel As Integer)
    If IsNull(txtName) Or Len(Trim(txtName)) = 0 Then
        MsgBox "You MUST supply a Name"
        txtName.SetFocus
    End If
End Sub

Open in new window

0
 
LVL 6

Expert Comment

by:jparul
ID: 24298608

Here's one recommended solution using VBA
Create an array like this:

CheckNamS = Array(Me.chkNamc, me.txtField1, me.opttest, me.cboTest2)
vNamString = "" 
For Each vNamName In CheckNamS
    If vNamName.Value = -1 Then
        vNamString = vNamString & vNamName.Tag & ", "
    End If
Next
Msgbox("following fields are missing" & vNamString)

0
Online Training Solution

Drastically shorten your training time with WalkMe's advanced online training solution that Guides your trainees to action. Forget about retraining and skyrocket knowledge retention rates.

 

Author Comment

by:SueMos
ID: 24298656
Should I put it on the "OnClick" for the save button?? Or just the general "BeforeUpdate" of the form?
0
 
LVL 16

Expert Comment

by:Chuck Wood
ID: 24298703
Either one will work but I would use the OnClick event of the Save button.
0
 

Author Comment

by:SueMos
ID: 24298761
It errors 'variable not defined' and highlights the cancl = true line?
0
 

Author Comment

by:SueMos
ID: 24298783
cancel
0
 

Author Comment

by:SueMos
ID: 24298797
Sorry, I didn't see all of my options, let me try something else.
0
 

Author Comment

by:SueMos
ID: 24298813
CheckNamS gives me a varibale not defined...
0
 

Author Closing Comment

by:SueMos
ID: 31577715
It works!! Thanks!!
0
 
LVL 6

Expert Comment

by:jparul
ID: 24298844
declare CheckNamS as variant
dim CheckNamS as variant
0
 
LVL 75
ID: 24300172
"You can use the OnExit event to trigger a check of the txt field (or memo field). "

The best place to do this is the Before Update event of the control (or the Form).  On Exit is going to trigger that code *every* time you exit the control - even if a user is just tabbing though the control and the control already has correct data, thus running the code needlessly.  The BU is intended for validation of this nature.

Also, using the BU of each control *does not* cover the case when the user never actually enters the control.  This is why I suggested the Form's Before Update - which will prevent a save from occurring if any of the validations failed.

I highly recommend you use the Form BU instead of each Control's On Exit or Before Update.

mx
0

Featured Post

Technology Partners: We Want Your Opinion!

We value your feedback.

Take our survey and automatically be enter to win anyone of the following:
Yeti Cooler, Amazon eGift Card, and Movie eGift Card!

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

In a multiple monitor setup, if you don't want to use AutoCenter to position your popup forms, you have a problem: where will they appear?  Sometimes you may have an additional problem: where the devil did they go?  If you last had a popup form open…
You need to know the location of the Office templates folder, so that when you create new templates, they are saved to that location, and thus are available for selection when creating new documents.  The steps to find the Templates folder path are …
Familiarize people with the process of retrieving data from SQL Server using an Access pass-thru query. Microsoft Access is a very powerful client/server development tool. One of the ways that you can retrieve data from a SQL Server is by using a pa…
In Microsoft Access, learn different ways of passing a string value within a string argument. Also learn what a “Type Mis-match” error is about.

707 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