Action messages in access 2007 runtime

B

BobK

When I run an MDE in acess 2007 runtime, I get the action messages I.E. "1
record will be updated". DO I use:

DoCmd.SetWarnings False

to turn off these messages?

Thank you

BobK
 
T

Tony Toews [MVP]

BobK said:
When I run an MDE in acess 2007 runtime, I get the action messages I.E. "1
record will be updated". DO I use:

DoCmd.SetWarnings False
to turn off these messages?

You could but it's not recommended.

I prefer, if DAO, to use Currentdb.Execute strSQL,dbfailonerror
command instead of docmd.runsql. For ADO use
CurrentProject.Connection.Execute strCommand, lngRecordsAffected,
adCmdText

If you're going to use docmd.setwarnings make very sure you put the
True statement in any error handling code as well. Otherwise weird
things may happen later on especially while you are working on the
app. For example you will no longer get the "Do you wish to save your
changes" message if you close an object. This may mean that unwanted
changes, deletions or additions will be saved to your MDB.

Also performance can be significantly different between the two
methods. One posting stated currentdb.execute took two seconds while
docmd.runsql took eight seconds. As always YMMV.

Tony
--
Tony Toews, Microsoft Access MVP
Please respond only in the newsgroups so that others can
read the entire thread of messages.
Microsoft Access Links, Hints, Tips & Accounting Systems at
http://www.granite.ab.ca/accsmstr.htm
Tony's Microsoft Access Blog - http://msmvps.com/blogs/access/
 
B

BobK

Thank you. I have changed all my docmd.runsql to Currentdb.Execute
strSQL,dbfailonerror and the messages did indeed stop. Was this documented
somewhere that I might have missed that the preferred way is now
Currentdb.Execute strSQL,dbfailonerror? I would like to see if I am missing
anything, or changing something else.

BobK
 
T

Tony Toews [MVP]

BobK said:
Thank you. I have changed all my docmd.runsql to Currentdb.Execute
strSQL,dbfailonerror and the messages did indeed stop. Was this documented
somewhere that I might have missed that the preferred way is now
Currentdb.Execute strSQL,dbfailonerror? I would like to see if I am missing
anything, or changing something else.

I have no idea if this is officially recommended by Microsoft.
However I've been using currentdb.execute for close on to a decade
now.

Tony
--
Tony Toews, Microsoft Access MVP
Please respond only in the newsgroups so that others can
read the entire thread of messages.
Microsoft Access Links, Hints, Tips & Accounting Systems at
http://www.granite.ab.ca/accsmstr.htm
Tony's Microsoft Access Blog - http://msmvps.com/blogs/access/
 

Ask a Question

Want to reply to this thread or ask your own question?

You'll need to choose a username for the site, which only take a couple of moments. After that, you can post your question and our members will help you out.

Ask a Question

Top