running an Update Query

  • Thread starter Thread starter Brook
  • Start date Start date
B

Brook

Is there a way to run an update query upon opening a form
without the system confirming that you are about to run an
update query and asking if you want to proceed with update
(xxx) number of rows?

Brook
 
Brook,

On the main menu, under Tools/Options, click on the Edit/Find tab. Uncheck the three boxes, Record Changes, Document Deletions, and Action Queries.

Mark
 
MChrist said:
Brook,

On the main menu, under Tools/Options, click on the Edit/Find tab. Uncheck the
three boxes, Record Changes, Document Deletions, and Action Queries.
Hi Brook,

I don't recommend changing the settings above.

Instead, run your update query through Execute method
(using "dbFailOnError" so it doesn't "fail silently")

Private Sub Form_Open(Cancel As Integer)
On Error GoTo Err_Form_Open
Dim strSQL As String

strSQL = "UPDATE MyTable SET [f1] = 1"

'DAO execute
CurrentDb.Execute strSQL, dbFailOnError
'ADO execute
'CurrentProject.Connection.Execute strSQL, dbFailOnError

'or if update query is a stored query (say "qryupdf1")
'CurrentDb.Execute "qryupdf1", dbFailOnError

Exit_Form_Open:
Exit Sub

Err_Form_Open:
MsgBox Err.Description
Resume Exit_Form_Open
End Sub

Please respond back if I have misunderstood
or was not clear about something.

Good luck,

Gary Walter
 
Thanks for the information!

I do have a couple of questions. Where would I put the
code that you have suggested? And in what parts of the
code you suggested would I update with my updatequery and
or tblemaster?

Thyanks for your help!

Brook
-----Original Message-----

Brook,

On the main menu, under Tools/Options, click on the
Edit/Find tab. Uncheck the
three boxes, Record Changes, Document Deletions, and Action Queries.
Hi Brook,

I don't recommend changing the settings above.

Instead, run your update query through Execute method
(using "dbFailOnError" so it doesn't "fail silently")

Private Sub Form_Open(Cancel As Integer)
On Error GoTo Err_Form_Open
Dim strSQL As String

strSQL = "UPDATE MyTable SET [f1] = 1"

'DAO execute
CurrentDb.Execute strSQL, dbFailOnError
'ADO execute
'CurrentProject.Connection.Execute strSQL, dbFailOnError

'or if update query is a stored query (say "qryupdf1")
'CurrentDb.Execute "qryupdf1", dbFailOnError

Exit_Form_Open:
Exit Sub

Err_Form_Open:
MsgBox Err.Description
Resume Exit_Form_Open
End Sub

Please respond back if I have misunderstood
or was not clear about something.

Good luck,

Gary Walter


.
 
Hi Gary and Brook,
I hope you don't mind me joining in but I am having the
same problem.
I would rather not have to change the set-up but as you
suggest I would rather use code.
Unfortunately I am like Brook, in that I'm not sure where
you are suggesting for this code to be located and exactly
where I fit my queries into the code. Or does the code
your suggesting Gary, apply to all queries.

Regards
Nick
-----Original Message-----

Brook,

On the main menu, under Tools/Options, click on the
Edit/Find tab. Uncheck the
three boxes, Record Changes, Document Deletions, and Action Queries.
Hi Brook,

I don't recommend changing the settings above.

Instead, run your update query through Execute method
(using "dbFailOnError" so it doesn't "fail silently")

Private Sub Form_Open(Cancel As Integer)
On Error GoTo Err_Form_Open
Dim strSQL As String

strSQL = "UPDATE MyTable SET [f1] = 1"

'DAO execute
CurrentDb.Execute strSQL, dbFailOnError
'ADO execute
'CurrentProject.Connection.Execute strSQL, dbFailOnError

'or if update query is a stored query (say "qryupdf1")
'CurrentDb.Execute "qryupdf1", dbFailOnError

Exit_Form_Open:
Exit Sub

Err_Form_Open:
MsgBox Err.Description
Resume Exit_Form_Open
End Sub

Please respond back if I have misunderstood
or was not clear about something.

Good luck,

Gary Walter


.
 
Brook said:
I do have a couple of questions. Where would I put the
code that you have suggested? And in what parts of the
code you suggested would I update with my updatequery and
or tblemaster?
Hi Brook,

Forms (and controls) have specific events
that fire off within the life of its "being."

For example, a command button has a click
event that fires when a user clicks on the button.

I understood (rightly or wrongly) that you wanted
to run an update query when you opened a form.

In the database window, select the Forms object,
then select your form, then click on Design.

Click on the Properties icon in menu (looks like a
sheet of paper being held by a hand). You should
now be looking at all the Properties of the form.

If you scroll down to bottom, you will see all the
events that can fire when you run this form....

On Current...
Before Insert...
After Insert....
Before Update...
After Update...
.....
On Open..... <--****
On Load....
On Resize...
On Close...
......
On Click....
On Dbl Click....
....

I assumed you wanted to run this update
query in the "On Open" event of your form.

Find this event's row and double-click in the
white space of the row. You should get the text
"[Event Procedure]" in the white space, plus a
"Build button" at the far right (a square button with
3 lower dots, or elipses, sp?).

Click on the Build button and you will be shifted to
the "Microsoft Visual Basic" window with preliminary
code that might look like:

Option Compare Database

Private Sub Form_Open(Cancel As Integer)

End Sub


If this is the first code for your form, the first thing
I would always do is type in the following under "Option..."

Option Explicit

this will insure that all your variables are properly
declared (won't let you misspell a variable, for
instance).

I gave you several choices of how you might
execute your query. If you choose to use DAO,
click on Tools/References in the top menu, and
verify (or scroll down and select) selection of

Microsoft DAO x.xx Object Library

If your update query was a stored query
whose name was "qryupdf1", this might be
the code for your Form_Open event
(change "qryupdf1" to name of *your* query):

Private Sub Form_Open(Cancel As Integer)
On Error GoTo Err_Form_Open

CurrentDb.Execute "qryupdf1", dbFailOnError

Exit_Form_Open:
Exit Sub

Err_Form_Open:
MsgBox Err.Description
Resume Exit_Form_Open
End Sub

When done, click on Save icon in menu
(looks like floppy), then click on Debug/Compile..
in the top menu. Hopefully it will compile w/o
errors.

Then close the Visual Basic window.

Now, whenever you open this form,
the update query will be run.

Please respond back if I have misunderstood
or was not clear about something.

Good luck,

Gary Walter

:

Is there a way to run an update query upon opening a form
without the system confirming that you are about to run an
update query and asking if you want to proceed with update
(xxx) number of rows?
Hi Brook,

I don't recommend changing the settings above.

Instead, run your update query through Execute method
(using "dbFailOnError" so it doesn't "fail silently")

Private Sub Form_Open(Cancel As Integer)
On Error GoTo Err_Form_Open
Dim strSQL As String

strSQL = "UPDATE MyTable SET [f1] = 1"

'DAO execute
CurrentDb.Execute strSQL, dbFailOnError
'ADO execute
'CurrentProject.Connection.Execute strSQL, dbFailOnError

'or if update query is a stored query (say "qryupdf1")
'CurrentDb.Execute "qryupdf1", dbFailOnError

Exit_Form_Open:
Exit Sub

Err_Form_Open:
MsgBox Err.Description
Resume Exit_Form_Open
End Sub
 
Nick said:
I hope you don't mind me joining in but I am having the
same problem.
I would rather not have to change the set-up but as you
suggest I would rather use code.
Unfortunately I am like Brook, in that I'm not sure where
you are suggesting for this code to be located and exactly
where I fit my queries into the code. Or does the code
your suggesting Gary, apply to all queries.
Hi Nick,

As a general rule, SELECT queries are used as a
RecordSource for a form or report
(or a ControlSource for a control).

Action queries tend to be fired by events that
happen on your form, i.e., a command button
gets clicked, after a control gets updated, etc.

In the Properties of a control (including a form),
you get all the events that can be fired through
the life of that control. Each can have an event
procedure that runs when the event occurs.

In Access 2000 Help, expand topic

"Programming Information"

then expand the topic

"Working with Events"

(its up to you, but I suggest ignoring macro info)

Hopefully this will get you started.

Good luck,

Gary Walter
 
Action queries tend to be fired by events that
happen on your form, i.e., a command button
gets clicked, after a control gets updated, etc.

bad wording..I wish I had said:

As another general rule, one usually
executes action queries within an
event procedure, i.e., when a command
button gets clicked, or after a control gets
updated, etc.

For help on the DAO Execute method,

in Access 2000 Help,

expand "Microsoft Data Access Objects 3.60(DAO)"

then expand "DAO Methods Reference"

then expand "D-E" and choose "Execute"

Good luck,

Gary Walter
 
Back
Top