Crosstab for dynamic columned report in the Jasper report with JasperSoft Studio Tutorial
We cannot predict the number of records available in a database table. To display it in a jasper report, we have to generate the table dynamically. We use jasper report tables to achieve this. What if we want to generate a table with dynamic columns in the jasper report. With jasper report Crosstab, we can generate both columns and rows dynamically.
The output of the jasper report Crosstab tutorial
data:image/s3,"s3://crabby-images/de5b5/de5b515174c300f0418f75e5c28c060b2caf5878" alt="Output of the Jasper Report crosstab"
This tutorial we are not going to demonstrate how to create a new jasper report and other basic stuff. You can refer to our previous tutorials for the jasper report.
Let's drag and drop jasper report crosstab element into the main report.
data:image/s3,"s3://crabby-images/5f2aa/5f2aa567a6235ac8bd25ea3c87fb19dd5d706dfe" alt="Create crosstab Jasper report"
In the popup, We are going to select Create a crosstab using a new dataset. Click next. We are going to keep the default name for the data set, but you can change it.
data:image/s3,"s3://crabby-images/317b4/317b4786cc6c64bc8030d7ddbb4a3fdb199c78e7" alt="Crosstab data set configuration"
Click Next again. In this screen, I'm going to select musql_data_adaptor, which is already created in my jasper studio.
data:image/s3,"s3://crabby-images/4ade6/4ade6cf3c41d669045d78aa5485582caf3ae6a81" alt="Crosstab data adapter configuration"
Next screen, you will see all available databases in our jasper report data adapter. In this screen, you can select the required tables under a database.
data:image/s3,"s3://crabby-images/8d5ca/8d5ca14f2aada092db5894cc842a30bae20fb785" alt="Crosstab database and the tables"
Select the diagram tab on the right side of the screen and drag and drop your table into it. Before click Next, select the fields that you want to continue with.
data:image/s3,"s3://crabby-images/d5aec/d5aec65c548b056d9b40671e3a59a6984a9578a6" alt="Crosstab database and the table fields"
Next screen, select all the fields.
data:image/s3,"s3://crabby-images/cce93/cce934451f262fd39092f12a1c5a7f4bd2b36e73" alt="Crosstab database and the table fields"
Crosstab data structure is similar to a Map data structure. Each cell is mapped to a column and a row. You can consider columns and the row as 2 ids to uniquely identify a cell.
Click Next 2 times. You will see the below screen. Here you can select the data member that use to generate columns of the jasper report crosstab.
data:image/s3,"s3://crabby-images/54f04/54f04e8dca611313c0cb7b13ad53f96067b006ae" alt="Crosstab define columns"
In the next screen, you need to select a data member to use as a row id. Here i'm selecting student name field.
data:image/s3,"s3://crabby-images/fb5ca/fb5ca5db7f63abf981af720ece41289af2c9cbb7" alt="Crosstab define row id"
In the next screen, you need to select a data member for measures. For each measure, you can have an aggregate method. I'm not going to select any aggregate calculations here. So I will select the First option.
data:image/s3,"s3://crabby-images/5d3bf/5d3bf0749f77aa5cabe6b9852159b13bf6166769" alt="Crosstab define measures"
In the next screen, you can change the colors and other styles. Click Finish.
data:image/s3,"s3://crabby-images/8f450/8f450f125d7fafae424ad2d78373ece65ef1d47e" alt="Jasper report Crosstab"
Adjust the size and place of the jasper report crosstab. After that its ready to preview. Click on the preview. Then, you can see the output of jasper crosstab.
data:image/s3,"s3://crabby-images/4ff0d/4ff0d9224f826953863c288b3bb33f32cf4a4de4" alt="Jasper report Crosstab preview"
We have created our first jasper report example about the jasper report crosstab element.
Check out our video. for the more information up to now.
How to set a default value to a jasper report crosstab cell with null value
Click on the detail element on the Outline Palette as below.
data:image/s3,"s3://crabby-images/40404/4040499e76790dfe4b48ce64bc5ebc86b27bf7cd" alt="Jasper report Crosstab Outline Palette"
Go to the properties of the element. Under Text Field properties, you can configure what to do with null values.
By selecting "Blank When NULL" option, you can set your nullable cells to blank.
data:image/s3,"s3://crabby-images/6da83/6da83a944047091abc563ec0fb1e54ae055a998b" alt="Jasper report Crosstab cell blank when null"
You can do more customizable data manipulation from the "Expression" option. Click on the Expression button.
data:image/s3,"s3://crabby-images/93df0/93df0914789e3540c4f09328a10f99f7c85ac50a" alt="Jasper report Crosstab Cell Expression"
In the jasper report expression editor, you can write custom code to manipulate jasper report crosstab cell data.
data:image/s3,"s3://crabby-images/24a3a/24a3ac018b33430805ee2572f91c8ff158d3ee41" alt="Jasper report Crosstab Cell Expression"
Now you are almost ready. Click on the preview tab and preview the final results of the jasper report crosstab after setting a default value for the null cells.
data:image/s3,"s3://crabby-images/179a2/179a2ff56471acdb31fe7c7fcd2573196eb428b3" alt="Jasper report Crosstab final preview"
For more information, check out our video.