This article records the steps to implement subreports and their master report using JasperReport (iReport) and deploy them to SpagoBI reporting server.
Both sub-reports and master report are reports. Sub-reports, like building blocks, can be insert into master report to generate complex reports.
Environment
============
============
SpagoBI: version 2.5
Data Source: OE example database on Oracle 11g R2
Data Source: OE example database on Oracle 11g R2
iReport : version 3.7.3
1) Create a sub-report to display the order items detail for one order.
Open iReport, create the order items detail report -- “subreport_orderitems”
Report Query:
data:image/s3,"s3://crabby-images/5e311/5e31102bc0be9f2007eba15e1e4a2a7f2ff46ac8" alt=""
Report Layout:
data:image/s3,"s3://crabby-images/6ae54/6ae540c332a52701534554adb098fd1b4e11312f" alt=""
2) Create the master report to show order level data and insert the sub-report (detail) to show the order item level data.
Using iReport to create the master (order level) report -- “Master_Order”
Report Query:
data:image/s3,"s3://crabby-images/ba5bf/ba5bf434f0231f3a5343343bf874454f697a89b0" alt=""
Report Layout:
data:image/s3,"s3://crabby-images/5d71a/5d71a8ab5ef37f0b8f4b6253f6fae9a712f9157c" alt=""
Sub-report Parameter:
data:image/s3,"s3://crabby-images/f02a6/f02a6c0f7fda115c7bbaee44a1f4baad7b32f01d" alt=""
Setup sub-report parameter(s) in master report will let master report know how to pass values to sub-0report.
Create a variable (parameter) -- “SBI_RESOURCE_PATH”
On SpagoBI reporting server, this variable will point to folder: Tomcat_home/resources/img/
Later, we will copy resource files (needed by this example) to the above folder on SpagoBI server.
On developer workstation (in iReport), we can set this variable a default value to point to a local folder where the image files reside.
Resource - Image Expression
data:image/s3,"s3://crabby-images/896a0/896a0898e8b1fc9018e81c96513a9e64046e8e30" alt=""
And
data:image/s3,"s3://crabby-images/cb31f/cb31f1bd4dbc691a510fef426896e2314e7503d2" alt=""
Subreport Expression:
The subreport file (“subreport_orderitems”) should be just referenced (or pointed) by its name in master report (“Master_Order”).
data:image/s3,"s3://crabby-images/0f3a4/0f3a4cdfbc24e03397c6227ae75d96641e990ca4" alt=""
Finally, test the Master / subreport.
3) Prepare to deploy to SpagoBI reporting server
Copy the resource files (in this example, two image files “coffee.jpg” and “coffee_stain.png”) from your local developing environment to the folder on SpagoBI reporting server: Tomcat_home/resources/img/
4) Deploy to SpagoBI reporting server
First, add an analytical driver for the parameter (in this example, the parameter name is “p_OrderID”) used in the report, as below:
data:image/s3,"s3://crabby-images/beba7/beba7a349afa866df219d73c4331b7b1304f1293" alt=""
You may also need to specify the “Roles Associations” and “Predefined Value Constraints” for this parameter.
data:image/s3,"s3://crabby-images/ac97f/ac97f59f4e88947a500a946578be247a5512e5d8" alt=""
Click the “Save and return” button.
Then, click “insert” button to insert the “Document” for sub-report:
data:image/s3,"s3://crabby-images/c84b3/c84b3188ee286047e4abb849f3c8ff26eba033b1" alt=""
data:image/s3,"s3://crabby-images/b2787/b2787785e6be6f6775f2d2e21c0c45c18c2e9c8a" alt=""
Click the “Save and return” button.
Next, click “insert” button to insert a “Document” for the Master report:
data:image/s3,"s3://crabby-images/72c20/72c20d0dda40ac1b701fd9848f8079e92e82b6d4" alt=""
data:image/s3,"s3://crabby-images/b2787/b2787785e6be6f6775f2d2e21c0c45c18c2e9c8a" alt=""
data:image/s3,"s3://crabby-images/e89b2/e89b2bf1994032c22fe2da6da13f06d27d6a78e9" alt=""
Click the “Save and return” button.
Click the “Save and return” button.
Test the Master report:
Click “User Menu” --> “Documents Execution”, and run the report “OrderEntry_Master”:
data:image/s3,"s3://crabby-images/18926/18926a577b0c18a50a89d4d698f1b14b42ce01ca" alt=""
Final report output: