Page 5 of 5
Re: Refreshing xbrowse when dataset is closed and re-opened
Posted: Fri Jul 16, 2010 7:37 pm
by Carles
James,
Can you tried to use OLE DB for ODBC Drivers ?
data:image/s3,"s3://crabby-images/ce032/ce032d1c83003aff33b7eb1a9233e5551055c17b" alt="Image"
In the conection folder u need select dBase files and especify the path. In this example i've got the exe in c:\test and customer.dbf in c:\temp\data
data:image/s3,"s3://crabby-images/1dc4a/1dc4ad9f313d26ca259b822c4e687f4ad87a0b42" alt="Image"
Now, you can see the correct conection string if u need to use...
data:image/s3,"s3://crabby-images/006e7/006e7beff174b2646d2d15047aa46f63f0175340" alt="Image"
And finally i execute this sentence "Select * from customer where age > 80 order by first"
data:image/s3,"s3://crabby-images/3c78a/3c78a0ad553b76b820cd6e6ff0322a30b58502cf" alt="Image"
Re: Refreshing xbrowse when dataset is closed and re-opened
Posted: Fri Jul 16, 2010 8:03 pm
by James Bott
Carles,
Yes, I did everything as you showed and I get the unknownName "open" error both with and without the WHERE clause.
James
Re: Refreshing xbrowse when dataset is closed and re-opened
Posted: Fri Jul 16, 2010 8:37 pm
by Carles
James,
It's very strange, i don't know, i'm sorry
data:image/s3,"s3://crabby-images/ac336/ac336be094e065c931ddc616cf1af35eab6ac7c9" alt="Sad :("
.
Re: Refreshing xbrowse when dataset is closed and re-opened
Posted: Sat Jul 17, 2010 2:09 am
by Armando
nageswaragunupudi wrote:Yes, curiously oRs:Refresh() does not give any error, but this is no where officially documented and I am not sure what it does or does not do. I can be sure of what is documented by Microsoft and many other books on the subject.
Friends, pls review this link
http://msdn.microsoft.com/en-us/library ... 16(v=VS.85).aspx
Regards
Re: Refreshing xbrowse when dataset is closed and re-opened
Posted: Sat Jul 17, 2010 4:45 am
by nageswaragunupudi
Armando wrote:nageswaragunupudi wrote:Yes, curiously oRs:Refresh() does not give any error, but this is no where officially documented and I am not sure what it does or does not do. I can be sure of what is documented by Microsoft and many other books on the subject.
Friends, pls review this link
http://msdn.microsoft.com/en-us/library ... 16(v=VS.85).aspx
Regards
Clicking on the above link does not work. Those who want to see this page may please copy this link "http://msdn.microsoft.com/en-us/library/ms677516(v=VS.85).aspx" and paste in the address bar.
What this page lists are ADO methods, but not only those methods applicable to Recordset object. We all know for a long time that there is one Refresh method in ADO, but that applies to Collection Objects.
Sure there is a mention of Refresh method in this page. Please click on the "Refresh method" to go to the page where Refresh method is explained. To what this method applies to and what it does.
Clicking on Refresh method takes us to this page:
"http://msdn.microsoft.com/en-us/library/ms675046(v=VS.85).aspx".
In this page it is clearly explained that Refresh method applies to collections.
At the end of this page under "Applies To" section, it is clearly mentioned to what all collection objects the Refresh method applies and we all know this information all along.
This is the link to properties, methods and events of Recordset object:
"http://msdn.microsoft.com/en-us/library/ms675841(v=VS.85).aspx"
You will see that Refresh method is NOT documented here.
So, even if it does not error out, please do not use oRs:Refresh() and keep expecting that it does something what we in our minds like it to do.
So we come back to the original point. There is no documented method Refresh() for RecordSet object.
Re: Refreshing xbrowse when dataset is closed and re-opened
Posted: Sat Jul 17, 2010 5:43 pm
by nageswaragunupudi
We have seen in the earlier post that Refresh method for Recordset is not documented.
Though oRs:Refresh() does not error out, this does not read data again from the table and refresh the recordset. I humbly advise my friends not to depend on oRs:Refresh() for this purpose.
Use oRs:Requery() instead. This reads all the data based on oRs:Source again from the database and refreshes data in the recordset.
Here is a sample program to show that oRs:Refresh() does not really read the data again.
Code: Select all | Expand
#include 'fivewin.ch'
#include 'xbrowse.ch'
#define BS Chr(92) // BackSlash
#define FWPATH "c:" + BS + "fwh" + BS + "samples" + BS
static oCn
function Main()
local cStr := "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=" + ;
FWPATH + "xbrtest.mdb;User Id=admin;Password=;"
local cSql, oRs
// Open Connection
oCn := TOleAuto():New( "ADODB.Connection" )
oCn:Open( cStr )
oCn:CursorLocation := 3 // adUseClient
// Open Recordset. Single record
cSql := 'SELECT SALARY FROM CUSTOMER WHERE FIRST = "Ali"'
oRs := TOleAuto():New( "ADODB.RecordSet" )
oRs:Open( cSql, oCn )
MsgInfo( oRs:Fields( 0 ):Value, 'SALARY' ) // 30800.00 in my case
// Double the salary directly in the table ( Recordset does not know )
cSql := 'UPDATE CUSTOMER SET SALARY = 2 * SALARY WHERE FIRST = "Ali"'
oCn:Execute( cSql )
// Now the value in the table is 61600
MsgInfo( oRs:Fields( 0 ):Value, 'AFTER UPDATE' ) // 30800, because recordset does not know the change
oRs:Refresh()
MsgInfo( oRs:Fields( 0 ):Value, 'AFTER REFRESH' ) // Still shows 30800.00 Refresh() did not read again
oRs:ReQuery()
MsgInfo( oRs:Fields( 0 ):Value, 'AFTER REQUERY' ) // Now shows 61800. Correct
// Restore original value before exit
cSql := 'UPDATE CUSTOMER SET SALARY = SALARY / 2 WHERE FIRST = "Ali"'
oCn:Execute( cSql )
oRs:Close()
oCn:Close()
return nil
There is also another method ReSync(). This method is much faster and has many options. But please use this with extreme caution. Not all providers support this method and even where supported it does not work as expected with all parameters on all kinds of recordsets in the same way.
Please thorougly test this method on the target databae before using. Not advised for cross RDMS programming.
Re: Refreshing xbrowse when dataset is closed and re-opened
Posted: Sat Jul 17, 2010 8:44 pm
by James Bott
Rao,
In the original example showing oRS:Refresh(), even oRS:Requery() wasn't needed. It was right after the recordset was created.
James
Re: Refreshing xbrowse when dataset is closed and re-opened
Posted: Thu Mar 22, 2018 3:06 am
by nageswaragunupudi
This is better
Code: Select all | Expand
WITH OBJECT oBrw
:lScreenUpdating := .f.
:oRs:Close()
:oRs:Source := <revised SQL statement>
:oRs:Open()
:GoTop()
:lScreenUpdating := .t.
:Refresh()
END