Dynamics AX 2009: Creating a simple SSRS Report
Dynamics AX 2009 features support for writing reports using SQL Server Reporting Services. In this post, I’m going to show you how to create a simple SSRS report that accesses data in the AX database.
The overall process I will describe will focus on the first stage of authoring and deploying the report from the developers perspective.
In future posts I’ll cover
- Formatting the report
- Adding menu items to launch the report
- Security
- Accessing OLAP data
- etc.
The basic steps
- Create an AX Query
- Create a new AX Reports Project and a new report in that project
- Create a dataset in the report bound to that query
- Create a design to report to render the dataset
- Preview the design
- Deploy the design to SSRS
- View the report via IE
- Save the Report project back into AX
The report I will create will be a simple unformatted table of customers and customer IDs.
Create an AX Query
Launch the Dynamics Client
data:image/s3,"s3://crabby-images/c9999/c999960c1460cbd82d86a6f2a2851e7fd0026518" alt=""
Open the AOT
data:image/s3,"s3://crabby-images/bcd88/bcd887d618d745fc7a3210d2fcefd95d0dede586" alt=""
data:image/s3,"s3://crabby-images/04700/047007cc7da8d4cd486e2fd4a289924cd3ce1106" alt=""
In the AOT, right click on Queries and select New Query
data:image/s3,"s3://crabby-images/ed6db/ed6db4d275e96309f9458365f58d898dd037f831" alt=""
By default a new query will be create with a default name (in this case “Query1”)
data:image/s3,"s3://crabby-images/0ab59/0ab5989cedf2f2e13e1f077520f586d2e2d8b687" alt=""
Right-Click on that query and select Rename
Give it the name “DemoQueryCustomers” and hit RETURN
data:image/s3,"s3://crabby-images/1428b/1428b0be8686d66c1f85f5d2ce47eab0a4f08605" alt=""
data:image/s3,"s3://crabby-images/76c54/76c54f1b199a64dfe398f8c8016c16763c588fc3" alt=""
Expand that query in the AOT
data:image/s3,"s3://crabby-images/903c0/903c0ee93353bfb78bd3d92734a5ab281e197984" alt=""
Right-click on Data Sources and click New Data Source
A new data source will be created and by default attached to some table (in this case it will be called “Address_1”
data:image/s3,"s3://crabby-images/ffc11/ffc119d63d2cf6bf50fec80e9901fea291ae6372" alt=""
data:image/s3,"s3://crabby-images/3b7a2/3b7a2d7c979329a407b20e5aad546c8f615be050" alt=""
If you hover over this datasource you will see the query string
data:image/s3,"s3://crabby-images/0fe08/0fe08e1fc2ff42442573dc0f53b4c451cbc17760" alt=""
Right click on that data source and select Properties
data:image/s3,"s3://crabby-images/690f8/690f878a2dafedd0311afbcc4091b4974c294b9e" alt=""
The property window for that data source will appear
data:image/s3,"s3://crabby-images/bddfc/bddfc89411dbaae8b4af8b84cd959a5e7626c447" alt=""
Navigate to the Table property and change it to the “CustTable”
data:image/s3,"s3://crabby-images/5b2e9/5b2e929cf2ae13a94f2af800c1029c440c7766f4" alt=""
Click on the Name property
You’ll notice that the Name changes to “Cust_Table_1”
data:image/s3,"s3://crabby-images/d6f04/d6f049d7f6f8d9a7937a2c5a8d7f532da96e3e38" alt=""
Close the property window
data:image/s3,"s3://crabby-images/44a72/44a7245914283054b59455d9b49f40e0de230f91" alt=""
data:image/s3,"s3://crabby-images/ae094/ae094da32b5a2e2121bbb9e2f3528781d2f2aed5" alt=""
Click Save All in the AOT
data:image/s3,"s3://crabby-images/7e872/7e8720ae8449d7c8b2ffd3039b895811fa06ea70" alt=""
Close the AOT
data:image/s3,"s3://crabby-images/5178a/5178a0c93a56b8c718b7158f02c24b047b8a69bd" alt=""
Create a new AX Reports Project and a new report in that project
Launch Visual Studio 2008
data:image/s3,"s3://crabby-images/1f9c6/1f9c6f75af1d5130d8942d02e0f7713a3805c10a" alt=""
File > New > Project
data:image/s3,"s3://crabby-images/b108b/b108bece2dfdf0135f15b8589e0622e3cb9c0085" alt=""
The New Project dialog will launch
Under Project Types, select Visual C# / Dynamics
Under Templates select Dynamics AX Reporting Project
Change the Name to “DemoReportsLibrary1”
Click OK
data:image/s3,"s3://crabby-images/85fcb/85fcb69527fa4d9943a1711a27a12fd05354a424" alt=""
An new AX Report Library project is created
By default it contains a report called “Report1”
Right click on this report and rename it to “DemoReportCustomers”
data:image/s3,"s3://crabby-images/82767/827670a26010a40e36276cd9970ba83b4df38164" alt=""
Create a dataset in the report that is bound to the AX query
In the report, right click on Datasets and select new Dataset
By default the name of the Dataset is “Dataset1".
Rename it to “DataSetCustomers”
data:image/s3,"s3://crabby-images/e7988/e798862dd7218fe851e4a89fac21b3b11a5244ca" alt=""
In the properties window for the Dataset
Verify that the Data Source is “Dynamics AX”
Verify that the Data Source Type is “Query”
Verify that the Default Layout is “Table”
Click on the Query field
data:image/s3,"s3://crabby-images/ad81a/ad81ae308aa105ea9d50571fa06f2b5190a858ef" alt=""
Click on the ellipsis button in the value for the Query field
data:image/s3,"s3://crabby-images/d0cee/d0cee5cb75a41dec94c5ba4301755ac1c26f093d" alt=""
A dialog will launch that will list all the queries in AX. It will take a few seconds to populate this dialog with all the queries so be patient.
data:image/s3,"s3://crabby-images/e8187/e8187bf72d5f53f987cf9ce7979b8a4e7a3730a4" alt=""
Under Select Query, choose the query you previously created “DemoQueryCustomers”
After you select that query the right column will be filled with fields from the query.
By default All will be selected.
Uncheck All
data:image/s3,"s3://crabby-images/b2b21/b2b217a7cf42029cbd812f8b21fcdfc8cb9561ec" alt=""
Check the AccountNum field
data:image/s3,"s3://crabby-images/9d0af/9d0aff356bfa89cc9e22485576f56d2988e6de3c" alt=""
Check the City field
data:image/s3,"s3://crabby-images/df6d6/df6d603eab951c4c549ef8af6336597c69f0e851" alt=""
Check the Name field
data:image/s3,"s3://crabby-images/f5d19/f5d19b330f1c716939b700d7e5cb45765124c64a" alt=""
Check the State field
data:image/s3,"s3://crabby-images/e62a5/e62a5f3f41404a7bd3968c3d87c08f889f54a1d6" alt=""
Click OK to close the dialog
You’ll now see that ”DataSetCustomers” contains all the fields you selected.
data:image/s3,"s3://crabby-images/1aae2/1aae28c5a7ecdd0708319b6111376be85997ecf0" alt=""
Select “DataSetCustomers” and drag it into the “Designs” node
data:image/s3,"s3://crabby-images/d9cc6/d9cc6353c2adc51632f9ae50ae9df8322891ef69" alt=""
After you finish dragging, you’ll see that a design has been created. It will be given the name “AutoDesign1”
data:image/s3,"s3://crabby-images/dbd04/dbd040544c2f9c17ceba1dfcd8bfbd19cafb9f72" alt=""
Preview the design
With AutoDesign1 selected, click Preview in the toolbar
data:image/s3,"s3://crabby-images/b5f75/b5f757daeae1b09eaa804109b5ae90b3e332ddab" alt=""
You’ll notice a message at the top of the preview saying “The design has validation warnings” and you can see the warnings in the error list at the bottom.
We’ll ignore this for now.
Click the Save icon to save the report
Deploy the design to SSRS
Right click on the solution and select Deploy
data:image/s3,"s3://crabby-images/4a32c/4a32c6168ef7a3a4bb9ebd5964147b92c413a38d" alt=""
At the status bar in the bottom you’ll see a message on the left and some animation on the right indicating that the deployment is in progress.
data:image/s3,"s3://crabby-images/86034/860347e0309c7eaa7a77273b827b0c28e569bb06" alt=""
Eventually it will say “Deployment succeeded” in the status bar
data:image/s3,"s3://crabby-images/a3335/a3335792d8c7b6124910d886fea9bd536fce4c58" alt=""
View the report via IE
Launch IE and navigate to your SSRS reports server (in this example it is http://isotopex1:81/reports/)
data:image/s3,"s3://crabby-images/1da0b/1da0b69dc71da836646e64d1b00f599765697324" alt=""
Navigate into the Dynamics link
data:image/s3,"s3://crabby-images/7b0f6/7b0f6a47a1d34bd69d103ad0730e059192299ab2" alt=""
Find the report we deployed
It will be listed as “DemoReportsLibrary.DemoReportCustomers.AutoDesign1”
Click on it to view the report
data:image/s3,"s3://crabby-images/bfe11/bfe115b012a26572b7400a90973f0b3011ec0e3e" alt=""
And now you’ll see the report
data:image/s3,"s3://crabby-images/4d2bc/4d2bc415d866952e5e41ba1be8bd52e0622f828a" alt=""
Save the Report project back into AX
Close IE
In the solution, right click the report project (not the solution) and select Save to AOD
data:image/s3,"s3://crabby-images/f6338/f63384012279695180ce7c53d8884a25583670fe" alt=""
Open the Dynamics AX client
Open the AOT
data:image/s3,"s3://crabby-images/bffff/bffffa0618a5ebb97a439e1404f4faf7a3a6e384" alt=""
In the AOT expand the Report Libraries node
you’ll see the report library “DemoReportsLibrary” is now in AX
if you need to edit the report library again just locate it in the AOT, right-click it and select Edit in Visual Studio
data:image/s3,"s3://crabby-images/3e1c8/3e1c80a84cf22c1c033f6b7c9535a0ebb874ee74" alt=""
No comments:
Post a Comment