Moving information from Access to Excel using VBA: "Do Until" code

Posted on 2014-09-22
Last Modified: 2014-09-23
I know the title of this question is vague, but I am not sure how to explain this simply.

I have a piece of code that moves information from an Access Database to an excel spreadsheet.

Right now it won't allow duplicates records to be shown on the spreadsheet. This is great with values like TheTO and TheSTOname. But I need to have the TheStaffName repeat with each of TheSTOnames.

I have tried to change the code to say "If rs!STO AND rs!TeamName = TheSTOname AND TheStaffName" and then remove the Else and End If from the section of the code
that moves TheSTOname and TheStaffName so that there is no extra Else statement, but that ends the process really quickly and only a few items from my database end up added to the spreadsheet.

Below is the code I am working with and some notes about what I need to have happen.

Do Until rs.EOF
'This piece does not allow the TO to repeat. If the TO is repeated, then it will just move to the next record until it finds one that does not repeat
    If rs!TO = TheTO Then
    'Same with the STO. Keeps the STO from repeating. If the STO is a duplicate, it goes to the next one.
        If rs!STO = TheSTOname Then
        'If the staff name duplicates, then it goes to the next record. THIS IS A PROBLEM. I need the staff names to repeat with the STOs
            If TheStaffName = rs!TeamName Then
            'If the ActDesc repeats, it will move to the next line.
                If theActDesc = rs!ActDesc Then
                'Starts writing the ActDesc to the spreadsheet
                    theRow = theRow + 1
                    oSheet.Cells(theRow, 4).Value = rs!ActDesc
                End If
            'Starts moving the staff names to the spreasheet. I want these connected to the sto name.
                theRow = theRow + 1
                oSheet.Cells(theRow, 3).Value = rs!TeamName
                TheStaffName = rs!TeamName

            End If
            theRow = theRow + 1
            oSheet.Cells(theRow, 2).Value = rs!STO
            TheSTOname = rs!STO
        End If
        theRow = theRow + 1
        oSheet.Cells(theRow, 1).Value = rs!TO
        TheTO = rs!TO
    End If

Open in new window

Thank you (in advance)!!!!
Question by:Megin
Welcome to Experts Exchange

Add your voice to the tech community where 5M+ people just like you are talking about what matters.

  • Help others & share knowledge
  • Earn cash & points
  • Learn & ask questions
  • 2

Author Comment

ID: 40337994
So, what it does is shown here (without the TO field). I have highlighted where I need to have the staff name duplicated. I don't want it duplicated for every activity, but just for every subtask.
LVL 34

Expert Comment

ID: 40338837
Create a query which generates your output. Then use the Range.CopyFromRecordset method to transfer the data.
LVL 15

Accepted Solution

JimFive earned 500 total points
ID: 40339253
When the STO changes set theStaffName = ""
That would be around line 28 in your snippet.

Author Closing Comment

ID: 40339474
That did it!

Thank you!!!!

Featured Post

Three Reasons Why Backup is Strategic

Backup is strategic to your business because your data is strategic to your business. Without backup, your business will fail. This white paper explains why it is vital for you to design and immediately execute a backup strategy to protect 100 percent of your data.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

This article describes a method of delivering Word templates for use in merging Access data to Word documents, that requires no computer knowledge on the part of the recipient -- the templates are saved in table fields, and are extracted and install…
Traditionally, the method to display pictures in Access forms and reports is to first download them from URLs to a folder, record the path in a table and then let the form or report pull the pictures from that folder. But why not let Windows retr…
Show developers how to use a criteria form to limit the data that appears on an Access report. It is a common requirement that users can specify the criteria for a report at runtime. The easiest way to accomplish this is using a criteria form that a…
In Microsoft Access, learn how to use Dlookup and other domain aggregate functions and one method of specifying a string value within a string. Specify the first argument, which is the expression to be returned: Specify the second argument, which …

728 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question