MS访问->;不删除旧行的Excel连接

MS访问->;不删除旧行的Excel连接,excel,vba,ms-access,Excel,Vba,Ms Access,我有一个在MS Access中运行项目的数据库,我想定期将其导入Excel工作表。然而,一旦项目完成,它就会从Access数据库中删除(当然,刷新后从Excel中删除。有没有办法保留Excel工作表中的现有行?我只想在Excel电子表格中添加新行,但不想删除已完成的旧行-项目。因此,您正在将Access数据导入Excel。简单。请尝试下面的脚本,并根据您的需要对其进行修改 Sub ADOImportFromAccessTable(DBFullName As String, _ Table

我有一个在MS Access中运行项目的数据库,我想定期将其导入Excel工作表。然而,一旦项目完成,它就会从Access数据库中删除(当然,刷新后从Excel中删除。有没有办法保留Excel工作表中的现有行?我只想在Excel电子表格中添加新行,但不想删除已完成的旧行-项目。

因此,您正在将Access数据导入Excel。简单。请尝试下面的脚本,并根据您的需要对其进行修改

Sub ADOImportFromAccessTable(DBFullName As String, _
    TableName As String, TargetRange As Range)
' Example: ADOImportFromAccessTable "C:\FolderName\DataBaseName.mdb", _
    "TableName", Range("C1")
Dim cn As ADODB.Connection, rs As ADODB.Recordset, intColIndex As Integer
    Set TargetRange = TargetRange.Cells(1, 1)
    ' open the database
    Set cn = New ADODB.Connection
    cn.Open "Provider=Microsoft.Jet.OLEDB.4.0; Data Source=" & _
        DBFullName & ";"
    Set rs = New ADODB.Recordset
    With rs
        ' open the recordset
        .Open TableName, cn, adOpenStatic, adLockOptimistic, adCmdTable 
        ' all records
        '.Open "SELECT * FROM " & TableName & _
            " WHERE [FieldName] = 'MyCriteria'", cn, , , adCmdText 
        ' filter records

        RS2WS rs, TargetRange ' write data from the recordset to the worksheet

'        ' optional approach for Excel 2000 or later (RS2WS is not necessary)
'        For intColIndex = 0 To rs.Fields.Count - 1 ' the field names
'            TargetRange.Offset(0, intColIndex).Value = rs.Fields(intColIndex).Name
'        Next
'        TargetRange.Offset(1, 0).CopyFromRecordset rs ' the recordset data

    End With
    rs.Close
    Set rs = Nothing
    cn.Close
    Set cn = Nothing
End Sub

为什么要删除数据?为什么不让项目处于访问状态?