可以使用VBA编写函数来实现动态FROM语句。以下是一个示例代码:
Public Function QueryUsingDynamicFrom(ByVal tableOne As String, ByVal tableTwo As String) As DAO.Recordset Dim qryDef As DAO.QueryDef Dim strSQL As String
'创建查询定义
Set qryDef = CurrentDb.CreateQueryDef("")
'构建SQL语句
strSQL = "SELECT * FROM [" & tableOne & "] INNER JOIN [" & tableTwo & "] ON [" & tableOne & "].ID = [" & tableTwo & "].ID;"
'将SQL语句与查询定义关联
qryDef.SQL = strSQL
'执行查询,并返回Recordset
Set QueryUsingDynamicFrom = qryDef.OpenRecordset()
'清除查询定义
Set qryDef = Nothing
End Function
这个函数接收两个参数:tableOne和tableTwo,表示需要连接的两个表的名称。它使用VBA的DAO库,创建一个空的查询定义,然后构建一个动态SQL语句,将其与查询定义关联,最后执行查询并返回Recordset。在这个例子中,动态SQL语句使用两个表名来构建一个INNER JOIN查询。这个函数可以在ACCESS的查询中使用,例如:
SELECT * FROM QueryUsingDynamicFrom("Table1", "Table2")
在这个例子中,“Table1”和“Table2”是要连接的两个表的名称。当查询执行时,这个函数将使用这两个表名来构建一个INNER JOIN查询,并返回该查询的结果集。