Solved

Output Access query to Excel

Posted on 2006-06-29
7
293 Views
Last Modified: 2012-05-05
I have seen numerous posts talking about how to save access query to an excel file.

I'm wondering if it is possible to output access query output to excel without saving it to a file.

I.e an instance of excel on my screen
0
Comment
Question by:johnnyg123
[X]
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
  • 3
  • 2
  • 2
7 Comments
 
LVL 35

Assisted Solution

by:Raynard7
Raynard7 earned 250 total points
ID: 17013848
Hi,

Yes - this can be done for example; the following code shows you how to write values to an excel sheet; if you want to do fancy things - record a macro in excel and then copy the code and insert it into the VBA code.  As you can reference the excel sheet by ordinal position ie (1,2) you can loop through a recordset and write the values.

there is no way to actually do it through something like acTransferText - as this will save - so you have to write the values yourself; the advantage is however you can create multiple worksheets and once you have a generic function you can pass all of your queries to it.

'************ Code Start **********
'This code was originally written by Dev Ashish
'It is not to be altered or distributed,
'except as part of an application.
'You are free to use it in any application,
'provided the copyright notice is left unchanged.
'
'Code Courtesy of
'Dev Ashish
'
Sub sTestXL()
Dim objXL As Object
Dim strWhat As String, boolXL As Boolean
Dim objActiveWkb As Object

    If fIsAppRunning("Excel") Then
        Set objXL = GetObject(, "Excel.Application")
        boolXL = False
    Else
        Set objXL = CreateObject("Excel.Application")
        boolXL = True
    End If
   
    objXL.Application.workbooks.Add
    Set objActiveWkb = objXL.Application.ActiveWorkBook
   
    With objActiveWkb
        .Worksheets(1).Cells(1, 1) = "Hello World"
        strWhat = .Worksheets(1).Cells(1, 1).value
    End With
   
    objActiveWkb.Close savechanges:=False
   
    If boolXL Then objXL.Application.Quit
   
    Set objActiveWkb = Nothing: Set objXL = Nothing
    MsgBox strWhat
End Sub
'************ Code End **********
0
 
LVL 65

Accepted Solution

by:
rockiroads earned 250 total points
ID: 17016297
Yes u can do exactly what u want. Its Excel Automation that is required as suggested by Raynard7

Here is sample code that opens excel, dumps the result of your query and leaves it open. It does not save to a file.
It makes use of CopyFromRecordset



Public Sub CreateExcelWBFromQuery()

    Dim sSql As String
    Dim objXL As Object
    Dim objWB As Object
    Dim rs As DAO.Recordset
   
   
    'Open a recordset for your query
    sSql = "SELECT * FROM Table3"
    Set rs = CurrentDb.OpenRecordset(sSql)
   
    'Create a new excel document
    Set objXL = CreateObject("Excel.Application")
   
    'To create new workbook
    Set objWB = objXL.Workbooks.Add
   
    'Paste the values from your query starting from A1
    objWB.Sheets(1).Range("A1").CopyFromRecordset rs

    'Show the user your glorious results
    objXL.Visible = True

     rs.Close    
     set rs=Nothing
End Sub


Note, if u do not have DAO setup as an object reference, you need to as that is what I use for getting results from a query.
Go to Tools/References and check the latest version.



0
 

Author Comment

by:johnnyg123
ID: 17019684
rockiroads,

Is it possible to use open record with a "predefined" query ?

I could copy the sql but would prefer just to use existing query if possible
0
MS Dynamics Made Instantly Simpler

Make Your Microsoft Dynamics Investment Count  & Drastically Decrease Training Time by Providing Intuitive Step-By-Step WalkThru Tutorials.

 
LVL 65

Expert Comment

by:rockiroads
ID: 17020473
u could try this

dim qdf as dao.querydef


set qdf = currentdb.querydefs("nameofyourquery")

Set rs = CurrentDb.OpenRecordset(qdf.sql)

0
 
LVL 35

Expert Comment

by:Raynard7
ID: 17021864
I agree with rockiroads - you can always use a queryDef instead of sql;

You can also just substitute the name in th reordset name ie;
Set rs = CurrentDb.OpenRecordset("nameofyourquery")
0
 

Author Comment

by:johnnyg123
ID: 17081401
Thanks for the input!


I will split the points
0
 
LVL 65

Expert Comment

by:rockiroads
ID: 17085964
No probs. Glad to have helped
0

Featured Post

Revamp Your Training Process

Drastically shorten your training time with WalkMe's advanced online training solution that Guides your trainees to action.

Question has a verified solution.

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

Access developers frequently have requirements to interact with Excel (import from or output to) in their applications.  You might be able to accomplish this with the TransferSpreadsheet and OutputTo methods, but in this series of articles I will di…
Did you know that more than 4 billion data records have been recorded as lost or stolen since 2013? It was a staggering number brought to our attention during last week’s ManageEngine webinar, where attendees received a comprehensive look at the ma…
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 …
With Secure Portal Encryption, the recipient is sent a link to their email address directing them to the email laundry delivery page. From there, the recipient will be required to enter a user name and password to enter the page. Once the recipient …

717 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