Solved

Access reports in VB

Posted on 2002-05-15
9
238 Views
Last Modified: 2013-11-28
Is it possible to 'use' access reports through VB?

can you open access and get the report open in print preview mode, or is there some way to do it without opening access? (i.e. a seperate report viewer/printer program hidden somewhere)

simple! but i still cant seem to do it :|

SiM99
0
Comment
Question by:SiM99
9 Comments
 
LVL 70

Expert Comment

by:Éric Moreau
ID: 7011556
it is not possible because the reports need to be runned by the Access engine. The only way is to rebuild your reports using a real reporting engine (Crystal Report, Active Report, ...)
0
 
LVL 1

Expert Comment

by:carpediem
ID: 7011653
I have just been having the same issue.  emoreau is right that you need the Access engine which means Access will have to be installed on any PC running the VB app that launches the report (which is a real pain for me).

Here is the code I am using until I can find something better.

                Set lAccess = CreateObject("Access.Application")
                               
                Set db = lAccess.Application.DBEngine.Workspaces(0).OpenDatabase(IPDBNAME, 0, False, ";pwd=X1JFH9")
                lAccess.Visible = False
                lAccess.OpenCurrentDatabase IPDBNAME, False
                Set db = Nothing
               
                lintResult = SetForegroundWindow(lAccess.hWndAccessApp)
                'The report should open in printpreview
                If RptDest = 0 Then
                    lAccess.DoCmd.OpenReport UCase(LstRptFile(lstReports.ListIndex)), acViewPreview
                    lintResult = ShowWindow(lAccess.hWndAccessApp, SW_SHOWNORMAL)
                'The report should just print
                Else
                    lAccess.DoCmd.OpenReport UCase(LstRptFile(lstReports.ListIndex)), acViewNormal
                   
                    lintResult = CloseHandle(lAccess.hWndAccessApp)
                    lAccess.CloseCurrentDatabase
                    Set lAccess = Nothing
                End If

I am using some api calls in this code to ensure that the report window is active once it is opened.

You can also check out my question:
http://www.experts-exchange.com/jsp/qManageQuestion.jsp?ta=visualbasic&qid=20300562

For me security of the database was an issue so I had to add some additional security in Access itself as well.
0
 
LVL 10

Expert Comment

by:arana
ID: 7011884
you can open access and have a report open in print preview mode with an access autorun macro, then call the report with printpreview

but this will work only with ONE report you choose

maybe if you try diferent access mdb with one report in each (yiack!!!)


0
Simplifying Server Workload Migrations

This use case outlines the migration challenges that organizations face and how the Acronis AnyData Engine supports physical-to-physical (P2P), physical-to-virtual (P2V), virtual to physical (V2P), and cross-virtual (V2V) migration scenarios to address these challenges.

 
LVL 1

Author Comment

by:SiM99
ID: 7013223
carpediem,

aight, im trying your code out. (Didnt know you could access docmd, cool :)
but, err... what does the RptDest variable hold, and what vartype is it?
0
 
LVL 1

Author Comment

by:SiM99
ID: 7013229
also,
i'm assuming that lAccess was a Access.Application...
and what variable type was db?
0
 
LVL 1

Author Comment

by:SiM99
ID: 7013312
One more thing, how have you you made your user accounts?

Tried the security/user accounts menu option, but that makes them in the current system workspace, so they wouldn't be transferred with the database.

Have you used this method, or have you attatched the accounts to your database?
0
 
LVL 1

Accepted Solution

by:
carpediem earned 100 total points
ID: 7013550
Sorry for not commenting better.

RptDest is just an integer.  It is just a variable I set elsewhere to tell if the report should just print or if it should open in print preview.  If you are trying to open it in print preview you can get rid of that entire if statement and just use what is in the Else part.

Correct lAccess is Access.Application
and db is Object

As far as the security your right.  I had just done this yesterday myself and had only tested it locally.  I'm pretty new to Access security as in the past I have only used Access as a back-end database where I would set the database password and not worry about individual user rights.  I guess I'll have to look into this some more.
0
 
LVL 1

Expert Comment

by:carpediem
ID: 7014038
OK about the security.  If you do a search in Access help about security and Access workgroups you can read about all of this better than I will explain here, but here is what I'm planning to do.

When you define permissions with user accounts it creates a workgroup information file (usually where Access is installed) and Access uses that file for security locally.  However, using a utility called the WorkGroup Administrator you can put the file on in the network location as your database and then using WorkGroup Administrator on the client machines tell them to get their security information from the workgroup information file on the network, not thier own local copy.

I still don't like this a whole lot, but I'm going to try it initially and see how it works.
0
 
LVL 1

Author Comment

by:SiM99
ID: 7073038
Thanks.
I had also found the information about the workspaces, but it seems silly to try and get a client to install a workspace - in our situation anyway, we dont have all clients networked! :)

Got the reports to open at least...
0

Featured Post

Comprehensive Backup Solutions for Microsoft

Acronis protects the complete Microsoft technology stack: Windows Server, Windows PC, laptop and Surface data; Microsoft business applications; Microsoft Hyper-V; Azure VMs; Microsoft Windows Server 2016; Microsoft Exchange 2016 and SQL Server 2016.

Question has a verified solution.

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

Enums (shorthand for ‘enumerations’) are not often used by programmers but they can be quite valuable when they are.  What are they? An Enum is just a type of variable like a string or an Integer, but in this case one that you create that contains…
Since upgrading to Office 2013 or higher installing the Smart Indenter addin will fail. This article will explain how to install it so it will work regardless of the Office version installed.
Using Microsoft Access, learn some simple rules for how to construct tables in a relational database. Split up all multi-value fields into single values: Split up fields that belong to other things into separate tables: Make sure that all record…
Access reports are powerful and flexible. Learn how to create a query and then a grouped report using the wizard. Modify the report design after the wizard is done to make it look better. There will be another video to explain how to put the final p…

803 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