Re: Dev Ashish Relink Tables

Tech-Archive recommends: Fix windows errors by optimizing your registry



I see that in the fGetLinkedTables function you have the following:

If Left$(.Connect, 4) = "ODBC" Then
' collTables.Add Item:=.Name & ";" & .Connect, KEY:=.Name
'ODBC Reconnect handled separately
Else
collTables.Add Item:=.Name & .Connect, Key:=.Name

I don't know this code well and it would take too much time to look through
everything, but from what I can see it looks like the code is appending the
Connect value to the Name value here. If it's not an ODBC connection, there's
nothing to separate the table name from the connect value. When you showed
what the Connect value was, you showed this:

MS
Access;PWD=FirstPwd;DATABASE=U:\Accounting\Ac01\CorporateAcctAc01\
TaxStreamFiles.mdb

When the table name is parsed in function fParseTable it looks for a ';' as
the delimiter. in your case, since you aren't using ODBC, there was no ';'
placed between the table name and the connect value, so it is taking the
table name concatenated with MSAccess, since there is a ';' right after
MSAccess in the connect value. That's what it looks like to me. I don't know
if you modified this code or if it's the original code you copied, and I
don't know what the intent is of not separating the table name from the
connect value if it's not ODBC, but it looks like that's what's causing your
problem from what I can tell.

Steven wrote:
I was trying to use this code by Dev Ashish

Down below in the code I put : ********Problem******** where I am first
noticing the problem develop
The code returns a strTbl for example of "TrialBalanceMS Access" and an
error will say:
"Table TrialBalanceMS Access" not found ... cannot relink

The tables actual name is "TrialBalance". Why is it adding MS Access onto
it. I am able to manually link the tables to the mdb just fine but I always
get this message when trying to use the code.

Thank you for your help.

Steven

'***************** Code Start ***************
' This code was originally written by Dev Ashish.
' It is not to be altered or distributed,
' except as part of an application.
' You are free to use it in any application,
' provided the copyright notice is left unchanged.
'
' Code Courtesy of
' Dev Ashish
'
Function fRefreshLinks() As Boolean
Dim strMsg As String, collTbls As Collection
Dim i As Integer, strDBPath As String, strTbl As String
Dim dbCurr As Database, dbLink As Database
Dim tdfLocal As TableDef
Dim varRet As Variant
Dim strNewPath As String

Const cERR_USERCANCEL = vbObjectError + 1000
Const cERR_NOREMOTETABLE = vbObjectError + 2000

On Local Error GoTo fRefreshLinks_Err

If MsgBox("Are you sure you want to reconnect all Access tables?", _
vbQuestion + vbYesNo, "Please confirm...") = vbNo Then Err.Raise
cERR_USERCANCEL

'First get all linked tables in a collection
Set collTbls = fGetLinkedTables

'now link all of them
Set dbCurr = CurrentDb

'strMsg = "Do you wish to specify a different path for the Access Tables?"

'If MsgBox(strMsg, vbQuestion + vbYesNo, "Alternate data source...") =
vbYes Then
strNewPath = fGetMDBName("Please select a new datasource")
'Else
' strNewPath = vbNullString
'End If

For i = collTbls.Count To 1 Step -1
strDBPath = fParsePath(collTbls(i))
strTbl = fParseTable(collTbls(i))
varRet = SysCmd(acSysCmdSetStatus, "Now linking '" & strTbl & "'....")
If Left$(strDBPath, 4) = "ODBC" Then
'ODBC Tables
'ODBC Tables handled separately
' Set tdfLocal = dbCurr.TableDefs(strTbl)
' With tdfLocal
' .Connect = pcCONNECT
' .RefreshLink
' collTbls.Remove (strTbl)
' End With
Else
If strNewPath <> vbNullString Then
'Try this first
strDBPath = strNewPath
Else
If Len(Dir(strDBPath)) = 0 Then
'File Doesn't Exist, call GetOpenFileName
strDBPath = fGetMDBName("'" & strDBPath & "' not found.")
If strDBPath = vbNullString Then
'user pressed cancel
Err.Raise cERR_USERCANCEL
End If
End If
End If

'backend database exists
'putting it here since we could have
'tables from multiple sources
MsgBox strDBPath
Set dbLink = DBEngine(0).OpenDatabase(strDBPath, False, False,
";PWD=FirstPwd")

'check to see if the table is present in dbLink
strTbl = fParseTable(collTbls(i))
********Problem********
If fIsRemoteTable(dbLink, strTbl) Then
'everything's ok, reconnect
Set tdfLocal = dbCurr.TableDefs(strTbl)
With tdfLocal
.Connect = ";Database=" & strDBPath
.RefreshLink
collTbls.Remove (.Name)
End With
Else
Err.Raise cERR_NOREMOTETABLE
End If
End If
Next
fRefreshLinks = True
varRet = SysCmd(acSysCmdClearStatus)
MsgBox "All Access tables were successfully reconnected.", _
vbInformation + vbOKOnly, _
"Success"

fRefreshLinks_End:
Set collTbls = Nothing
Set tdfLocal = Nothing
Set dbLink = Nothing
Set dbCurr = Nothing
Exit Function
fRefreshLinks_Err:
fRefreshLinks = False
Select Case Err
Case 3059:

Case cERR_USERCANCEL:
MsgBox "No Database was specified, couldn't link tables.", _
vbCritical + vbOKOnly, _
"Error in refreshing links."
Resume fRefreshLinks_End
Case cERR_NOREMOTETABLE:
MsgBox "Table '" & strTbl & "' was not found in the database" & _
vbCrLf & dbLink.Name & ". Couldn't refresh links", _
vbCritical + vbOKOnly, _
"Error in refreshing links."
Resume fRefreshLinks_End
Case Else:
strMsg = "Error Information..." & vbCrLf & vbCrLf
strMsg = strMsg & "Function: fRefreshLinks" & vbCrLf
strMsg = strMsg & "Description: " & Err.Description & vbCrLf
strMsg = strMsg & "Error #: " & Format$(Err.Number) & vbCrLf
MsgBox strMsg, vbOKOnly + vbCritical, "Error"
Resume fRefreshLinks_End
End Select
End Function

Function fIsRemoteTable(dbRemote As Database, strTbl As String) As Boolean
Dim tdf As TableDef
On Error Resume Next
Set tdf = dbRemote.TableDefs(strTbl)
fIsRemoteTable = (Err = 0)
Set tdf = Nothing
End Function

Function fGetMDBName(strIn As String) As String
'Calls GetOpenFileName dialog
Dim strFilter As String

strFilter = ahtAddFilterItem(strFilter, _
"Access Database(*.mdb;*.mda;*.mde;*.mdw) ", _
"*.mdb; *.mda; *.mde; *.mdw")
strFilter = ahtAddFilterItem(strFilter, _
"All Files (*.*)", _
"*.*")

fGetMDBName = ahtCommonFileOpenSave(Filter:=strFilter, _
OpenFile:=True, _
DialogTitle:=strIn, _
Flags:=ahtOFN_HIDEREADONLY)
End Function

Function fGetLinkedTables() As Collection
'Returns all linked tables
Dim collTables As New Collection
Dim tdf As TableDef, db As Database
Set db = CurrentDb
db.TableDefs.Refresh
For Each tdf In db.TableDefs
With tdf
If Len(.Connect) > 0 Then
If Left$(.Connect, 4) = "ODBC" Then
' collTables.Add Item:=.Name & ";" & .Connect, KEY:=.Name
'ODBC Reconnect handled separately
Else
collTables.Add Item:=.Name & .Connect, Key:=.Name
End If
End If
End With
Next
Set fGetLinkedTables = collTables
Set collTables = Nothing
Set tdf = Nothing
Set db = Nothing
End Function

Function fParsePath(strIn As String) As String
If Left$(strIn, 4) <> "ODBC" Then
fParsePath = Right(strIn, Len(strIn) _
- (InStr(1, strIn, "DATABASE=") + 8))
Else
fParsePath = strIn
End If
End Function

Function fParseTable(strIn As String) As String
fParseTable = Left$(strIn, InStr(1, strIn, ";") - 1)
End Function
'***************** Code End ***************

--
Jim Burke

Message posted via AccessMonster.com
http://www.accessmonster.com/Uwe/Forums.aspx/access-modules/200905/1

.



Relevant Pages

  • Re: Refresh Access 2002 ODBC-Verbindungen nach MS SQL Server 2005
    ... Paradox als Paradox, ODBC als ODBC. ... Dim tdfLinked As TableDef ... Set dbs = CurrentDb ... Dim sql As String, sPkIndexName As String ...
    (microsoft.public.de.access.clientserver)
  • Re: Dev Ashish Relink Tables
    ... strTbl if it exists. ... If it's not an ODBC connection, ... Dim i As Integer, strDBPath As String, strTbl As String ...
    (microsoft.public.access.modulesdaovba)
  • Re: Refreshing Links
    ... Dim strMsg As String, collTbls As Collection ... Dim dbCurr As Database, dbLink As Database ... Dim tdf As TableDef ...
    (microsoft.public.access.modulesdaovba)
  • Re: help with Re-linking tables to SQL server
    ... Try adding the password to your connection string... ... Dim tdf As DAO.TableDef ... Dim strMsg As String ... For Each tdf In CurrentDb.TableDefs ...
    (comp.databases.ms-access)
  • Re: Dev Ashish Relink Tables
    ... Dim i As Integer, strDBPath As String, strTbl As String ... Dim tdf As TableDef ...
    (microsoft.public.access.modulesdaovba)