ms-access - 可以使用 VBA/ADO 连接两个记录集吗?

标签 ms-access ado

目标是将 Access 表与 SQL Server 表中的匹配数据连接起来。我会在 Access 中使用链接表来做到这一点,但我遇到了 Access 的 BigInt 问题(我会创建一个 View 来将 BigInt 转换为 Int,但这现在不是一个选项)。

所以我一直在尝试创建两个记录集并在 VBA/ADO 中加入它们。连接的左侧将是包含 Season 和 WeekNum 的 Access 表,连接的右侧将是包含 Season 和 Weeknum 以及其他数据的 SQL Server 表。这工作正常,直到我尝试创建作为联接结果的第三个记录集(在此示例中,我没有尝试进行联接,只是通过从 Access 记录集中选择来进行联接的第一部分)。当我执行 Set ObjRecordset3 = "SELECT * FROM "& Access_Recordset ' 时,在线路上出现类型不匹配错误。

甚至可以连接两个记录集吗?如果是这样,这是如何完成的?

Function Join()

    Dim SQL_Server_Connection As ADODB.Connection
    Set SQL_Server_Connection = New ADODB.Connection
    Dim SQL_Server_Query As String
    Dim SQL_Server_Recordset As New ADODB.Recordset

    Dim Access_Recordset As New ADODB.Recordset

    Dim ObjConnection As ADODB.Connection
    Set ObjConnection = CreateObject("ADODB.Connection")
    Dim ObjRecordset3 As New ADODB.Recordset

    ' Get data from Bump Table 3:
    Access_Recordset.Open "SELECT * FROM [Bump Table 3]", CurrentProject.Connection

    ' Open connection to SQL Server:
    SQL_Server_Connection_String = "DSN=MySQLServer"
    SQL_Server_Connection.Open SQL_Server_Connection_String

    ' Define the SQL Server query:
    SQL_Server_Query = "SELECT Season, WeekNum FROM TE"

    ' Populate the SQL_Server_Recordset:
    SQL_Server_Recordset.Open SQL_Server_Query, SQL_Server_Connection, adOpenDynamic, adLockOptimistic

    'Join Access_Recordset (Table: Bump Table 3) to SQL_Server_Recordset (Table: TE)
    Set ObjRecordset3 = "SELECT * FROM " & Access_Recordset ' Type Mismatch error on this line

    Access_Recordset.Close
    Set Access_Recordset = Nothing

    SQL_Server_Recordset.Close
    Set SQL_Server_Recordset = Nothing

    SQL_Server_Connection.Close

End Function

* 更新 *

我想出了如何实现我的最终目标,即根据两个表共有的帐号字段,从 SQL Server 获取有关 Access 表中帐号列表的数据。意识到我可以在 SQL Server 上创建一个持久性临时表,我使用 DAO 和 ADO 的组合从 Access 表中获取值并创建一个临时表。我所要做的就是运行引用临时表的传递查询。唯一奇怪的事情(此时不是问题)是如果我创建临时表并在 VBA 中运行传递查询,则此设置有效。但是如果我在 VBA 中创建临时表并双击传递查询,Access 会说找不到临时表。无论如何,这是代码:
Public Sub Insert_Into_Access_From_ADO_Recordset_Using_PTQ_Simpler()

    Dim dbs As DAO.Database
    Set dbs = CurrentDb()

    Dim cnn As ADODB.Connection
    Set cnn = New ADODB.Connection

    Dim rst As ADODB.Recordset

    'Open SQL Server
    Dim str_cnn As String
    str_cnn = "MYDSN"

    cnn.Open str_cnn

    ' Drop the temp table:

        Dim str_SQL_Drop_Temp_Table As String

        str_SQL_Drop_Temp_Table = "IF OBJECT_ID('tempdb..##BumpData','U') IS NOT NULL "
        str_SQL_Drop_Temp_Table = str_SQL_Drop_Temp_Table & " DROP TABLE ##BumpData "

        cnn.Execute str_SQL_Drop_Temp_Table


    ' Create the temp table:

        Dim str_SQL_Create_Temp_Table As String

        str_SQL_Create_Temp_Table = " CREATE TABLE ##BumpData "
        str_SQL_Create_Temp_Table = str_SQL_Create_Temp_Table & " " & "("
        str_SQL_Create_Temp_Table = str_SQL_Create_Temp_Table & " " & " ID INT "
        str_SQL_Create_Temp_Table = str_SQL_Create_Temp_Table & " " & " ,   AccountNumber VARCHAR(Max)"
        str_SQL_Create_Temp_Table = str_SQL_Create_Temp_Table & " " & ")"

        cnn.Execute str_SQL_Create_Temp_Table


    ' Insert values from the Access table into the temp table
    ' by looping through the Access table as a recordset:

        Dim rst_DAO As DAO.Recordset
        Set rst_DAO = dbs.OpenRecordset("Bump Data")

        Dim str_SQL_Insert As String

        rst_DAO.MoveFirst

        With rst_DAO
            Do While Not rst_DAO.EOF
                'str_Loan_Number_List = str_Loan_Number_List & "'" & Trim(rst![Loan Number]) & "'" & ","
                str_SQL_Insert = " INSERT INTO ##BumpData VALUES (" & rst_DAO![ID] & ",'" & Trim(rst_DAO![Loan Number]) & "') "
                cnn.Execute str_SQL_Insert
                .MoveNext
            Loop
        End With

    ' Run the pass-thru query which joins to the temp table:
    DoCmd.SetWarnings False
    DoCmd.RunSQL "SELECT * INTO [Bump Results] FROM [Bump PTQ]"
    DoCmd.SetWarnings True

End Sub

最佳答案

您报告此行触发错误:

Set ObjRecordset3 = "SELECT * FROM " & Access_Recordset

右侧= sign 尝试将字符串与 ADODB.Recordset 连接起来目的。这可能是编译错误的直接原因。然而,这并不是这条线的唯一问题。 Set <recordset object> = "any string value"不管用。最后,Access SQL 不支持 FROM <recordset object>适用于任何类型的记录集对象(ADO 或 DAO)。

我认为您应该寻找一种更简单的方法。在以下查询中,dbo_BigIntTable是指向 SQL Server 表的 ODBC 链接。它包括一个字段,bigint_fld ,其 SQL Server 数据类型为 BigInt。但是,Access 将该字段视为文本类型。因此,我可以将它与长整型字段( tblFoo.id )等价的字符串连接起来。

SELECT tblFoo.id, dbo_BigIntTable.bigint_fld
FROM
    tblFoo
    INNER JOIN dbo_BigIntTable
    ON CStr(tblFoo.id) = dbo_BigIntTable.bigint_fld;

Access 查询设计器提示它无法在设计 View 中显示该连接,但我能够从 SQL View 创建连接并且它运行良好。

关于ms-access - 可以使用 VBA/ADO 连接两个记录集吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14549673/

相关文章:

java - 使用 vector 从数据库填充 JTable 并在最后一列中显示复选框

excel - Microsoft Access 查询 - 根据日期查找数据

sql-server-2008 - ADODB.Recordset 错误 '800a0e78 对象关闭时不允许操作 : stored proc against temp table requiring SET NOCOUNT ON

vba - 无法使用 VBA 代码从 Excel 连接到 Teradata - 无法通过网络访问 Teradata 服务器

sql - VBscript 和 ADO - 3704 对象关闭时不允许操作

java - 如何使用java在ms access中插入值

ms-access - Access 2013 中的 VB 脚本在 QuickBooks Enterprise 14 中产生 "out of memory"错误

SQL 更新替换字符串中的部分文本

delphi - 如何通过代理使用ADO访问SQL Server?

xml - ADO 无法使用 native 客户端 (SQLNCLI) 访问 SQL Server XML 类型的列