如果您的目标只是检查 db 文件是否包含特定的链接表,则可以使用 ADOOpenSchema
方法。使用这种方法,您无需在 Access 应用程序会话中打开 db 文件,因此 AutoExec 宏不会运行。
下面是一个使用后期绑定的例子。如果您更喜欢早期绑定,我会留下评论说明。如果您的 Access 版本早于 2007,请 更改提供程序。
由于您使用的是 Access 用户级安全性,因此您还必须调整连接字符串以包含 MDW 的路径并提供 Access 安全性用户名和密码。这是来自ConnectionStrings.com的示例连接字符串(使用 Jet 4 提供程序)。为了便于阅读,我在分号上拆分了单行字符串:
Provider=Microsoft.Jet.OLEDB.4.0;
Data Source=C:\mydatabase.mdb;
Jet OLEDB:System Database=system.mdw;
User ID=myUsername;
Password=myPassword;
Public Function HasLinkedTable(ByVal pDb As String, _
ByVal pTable As String) As Boolean
Const adSchemaTables = 20&
Dim cn As Object ' ADODB.Connection
Dim rs As Object ' ADODB.Recordset
Dim strConnect As String
Dim blnReturn As Boolean
strConnect = "Provider=Microsoft.ACE.OLEDB.12.0;" & _
"Data Source=" & pDb & ";"
'Set cn = New ADODB.Connection
Set cn = CreateObject("ADODB.Connection")
cn.Open strConnect
Set rs = cn.OpenSchema(adSchemaTables)
With rs
Do While Not .EOF
If !TABLE_NAME = pTable And !TABLE_TYPE = "LINK" Then
'Debug.Print !TABLE_NAME, !TABLE_TYPE
blnReturn = True
Exit Do
End If
.MoveNext
Loop
.Close
End With
cn.Close
Set cn = Nothing
HasLinkedTable = blnReturn
End Function