Solved

How do I get ADOTable1.Post to immediatley update the database in delphi?

Posted on 2010-09-21
7
844 Views
Last Modified: 2013-11-23
I update data in a access (2003) database. I immediatley want to access the database and at the moment, I have to put a Sleep command in. I have seen comments on ApplyUpdates for other databases but Access doesn't have one. Is there something else I can use?
0
Comment
Question by:Neil_Jessop
  • 4
  • 3
7 Comments
 
LVL 5

Expert Comment

by:briangochnauer
ID: 33727925
ApplyUpdates  is part of the component TClientDataset;
What component are you using to access Access?  
dbExpress
TSQLQuery
TSQLTable
 ADO  
TADOTable
TADOQuery
BDE
TTable
TQuery
 
0
 

Author Comment

by:Neil_Jessop
ID: 33727995
I am using TADOTable to update the data, and TADOQuery to subsequently read it.
0
 
LVL 5

Expert Comment

by:briangochnauer
ID: 33728076
Huh? That can't work really.
The answer to your original question is use Post method like;
MyTable1.Post;
commits the data to the database; but I think you have other issues;
since you can update ADOTable without first reading it;
And if your querying with ADOQuery why not update it?
0
Industry Leaders: 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!

 

Author Comment

by:Neil_Jessop
ID: 33728194
I use a ADOTable.Post to commit the data to the database on one form.

On another form I try to read data, automatically, using a ADOQuery. The trouble is that when reading the data in the ADOQuery, it seems that the ADOTable.Post event hasn't written it to the database. If I put a Sleep(5000) between the ADOTable.Post and the read in using the ADOQuery, it works. But I have the problem that Sleep(5000) works on my machine but I have to use longer on other machines. I wondered if there was any other way?

0
 
LVL 5

Accepted Solution

by:
briangochnauer earned 250 total points
ID: 33728321
It's really a design problem not a Delphi problem.
Are these separate applications you're calling 'Forms"?

If not, put the ADO data objects in a DataModule; so they can share an ADOConnection
Or put the ADOConnection on a common unit.
Or you could use a ClientDataset object and local data provider in a DataModule
0
 
LVL 5

Expert Comment

by:briangochnauer
ID: 33728433
How do I get ADOTable1.Post to immediatley update the database in delphi?
Close it,  
ADOTable.Close;
0
 

Author Closing Comment

by:Neil_Jessop
ID: 33729579
Sort of answered but there is a better way.
0

Featured Post

On Demand Webinar - Networking for the Cloud Era

This webinar discusses:
-Common barriers companies experience when moving to the cloud
-How SD-WAN changes the way we look at networks
-Best practices customers should employ moving forward with cloud migration
-What happens behind the scenes of SteelConnect’s one-click button

Question has a verified solution.

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

Suggested Solutions

In this tutorial I will show you how to use the Windows Speech API in Delphi. I will only cover basic functions such as text to speech and controlling the speed of the speech. SAPI Installation First you need to install the SAPI type library, th…
Introduction I have seen many questions in this Delphi topic area where queries in threads are needed or suggested. I know bumped into a similar need. This article will address some of the concepts when dealing with a multithreaded delphi database…
Email security requires an ever evolving service that stays up to date with counter-evolving threats. The Email Laundry perform Research and Development to ensure their email security service evolves faster than cyber criminals. We apply our Threat…

756 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