Tutorial: Add a Sparkline to Your Report (Report Builder)
In this tutorial, you create a basic table report based on sample sales data, and then add a sparkline chart to a cell in the table.
An enhanced version of the report you create in this tutorial is available as a sample SQL Server 2014 Report Builder report. For more information about downloading this sample report and others, see Report Builder sample reports. The following illustration shows the sample report similar to the one that you will create.
The video How to: Create a Sparkline in a Table (Report Builder Video) illustrates how to create a similar report with sparklines.
What You Will Learn
In this tutorial, you will learn how to do the following:
Other Optional Steps
Estimated time to complete this tutorial: 30 minutes.
Requirements
For more information about requirements, see Prerequisites for Tutorials (Report Builder).
1. Create a Report with a Table
To create a report
Click Start, point to Programs, point to Microsoft SQL Server 2012 Report Builder, and then click Report Builder.
The Getting Started dialog box opens.
Note
If the Getting Started dialog box does not appear, from the Report Builder button, click New.
In the left pane, verify that New Report is selected.
In the right pane, click Table or Matrix Wizard.
On the Choose a dataset page, select Create a dataset, and then click Next. The Choose a connection to a data source page opens.
Note
This tutorial does not need specific data; it just needs a connection to a SQL Server 2014 database. If you already have a data source connection listed under Data Source Connections, you can select it and go to step 10. For more information, see Alternative Ways to Get a Data Connection (Report Builder).
Click New. The Data Source Properties dialog box opens.
In Name, type Product Sales, a name for the data source.
In Select a connection type, verify that Microsoft SQL Server is selected.
In Connection string, type the following text:
Data Source=<servername>
The expression <servername>, for example Report001, specifies a computer on which an instance of the SQL Server Database Engine is installed. Because the report data is not extracted from a SQL Server database, you need not include the name of a database. The default database on the specified server is used to parse the query.
Click Credentials. Enter the credentials that you need to access the external data source.
Click OK.
You are back on the Choose a connection to a data source page.
To verify that you can connect to the data source, click Test Connection.
The message "Connection created successfully" appears.
Click OK.
Click Next.
2. Create a Query in the Table Wizard
In a report, you can use a shared dataset that has a predefined query, or you can create an embedded dataset for use only in your report. In this tutorial, you will create an embedded dataset.
Note
In this tutorial, the query contains the data values, so that it does not need an external data source. This makes the query quite long. In a business environment, a query would not contain the data. This is for learning purposes only.
To create a query
On the Design a query page, the relational query designer is open. For this tutorial, you will use the text-based query designer.
Click Edit As Text. The text-based query designer displays a query pane and a results pane.
Paste the following Transact-SQL query into the Query box.
SELECT CAST('2010-01-04' AS date) as SalesDate, 'Accessories' as Subcategory, 'Carrying Case' as Product, CAST(16996.60 AS money) AS Sales, 68 as Quantity UNION SELECT CAST('2010-01-05' AS date) as SalesDate, 'Accessories' as Subcategory, 'Carrying Case' as Product, CAST(1350.00 AS money) AS Sales, 18 as Quantity UNION SELECT CAST('2010-01-10' AS date) as SalesDate, 'Accessories' as Subcategory, 'Carrying Case' as Product, CAST(1147.50 AS money) AS Sales, 17 as Quantity UNION SELECT CAST('2010-01-04' AS date) as SalesDate, 'Accessories' as Subcategory, 'Budget Movie-Maker' as Product, CAST(1056.00 AS money) AS Sales, 44 as Quantity UNION SELECT CAST('2010-01-05' AS date) as SalesDate, 'Accessories' as Subcategory, 'Slim Digital' as Product, CAST(1380.00 AS money) AS Sales, 18 as Quantity UNION SELECT CAST('2010-01-05' AS date) as SalesDate,'Accessories' as Subcategory, 'Budget Movie-Maker' as Product, CAST(780.00 AS money) AS Sales, 26 as Quantity UNION SELECT CAST('2010-01-07' AS date) as SalesDate, 'Accessories' as Subcategory, 'Budget Movie-Maker' as Product, CAST(3798.00 AS money) AS Sales, 9 as Quantity UNION SELECT CAST('2010-01-08' AS date) as SalesDate, 'Camcorders' as Subcategory, 'Budget Movie-Maker' as Product, CAST(10400.00 AS money) AS Sales, 13 as Quantity UNION SELECT CAST('2010-01-09' AS date) as SalesDate, 'Camcorders' as Subcategory, 'Budget Movie-Maker' as Product, CAST(3000.00 AS money) AS Sales, 60 as Quantity UNION SELECT CAST('2010-01-10' AS date) as SalesDate, 'Digital' as Subcategory, 'Budget Movie-Maker' as Product, CAST(7234.50 AS money) AS Sales, 39 as Quantity UNION SELECT CAST('2010-01-06' AS date) as SalesDate, 'Digital' as Subcategory, 'Carrying Case' as Product, CAST(10836.00 AS money) AS Sales, 84 as Quantity UNION SELECT CAST('2010-01-07' AS date) as SalesDate, 'Digital' as Subcategory, 'Slim Digital' as Product, CAST(2550.00 AS money) AS Sales, 17 as Quantity UNION SELECT CAST('2010-01-04' AS date) as SalesDate, 'Digital' as Subcategory, 'Slim Digital' as Product, CAST(8357.80 AS money) AS Sales, 44 as Quantity UNION SELECT CAST('2010-01-08' AS date) as SalesDate, 'Digital SLR' as Subcategory, 'Slim Digital' as Product, CAST(18530.00 AS money) AS Sales, 34 as Quantity UNION SELECT CAST('2010-01-06' AS date) as SalesDate, 'Digital SLR' as Subcategory, 'Slim Digital' as Product, CAST(26576.00 AS money) AS Sales, 88 as Quantity
On the query designer toolbar, click Run (!).
The query runs and displays the result set for the fields SalesDate, Subcategory, Product, Sales, and Quantity.
Click Next.
On the Arrange fields page, drag Sales to Values.
Sales is aggregated by the Sum function. The value is [Sum(Sales)].
Drag Product to Row groups.
Drag SalesDate to Column groups.
Click Next.
On the Choose the layout page, under Options, verify that Show subtotals and grand totals is selected.
The wizard Preview pane displays a table with three rows. When you run the report, each row will display in the following way:
The first row will appear once for the table to show column headings.
The second row will repeat once for each product and display the product name, total per day, and line total.
The third row will appear once for the table to display the grand totals.
Click Next.
On the Choose a Style page, in the Styles pane, select Slate.
The Preview pane displays a sample of the table with that style.
Click Finish.
The table is added to the design surface. The table has three columns and three rows.
Look in the Grouping pane. If you can't see the Grouping pane, on the View menu, click Grouping. The Row Groups pane shows one row group: Product. The Column Groups pane shows one column group: SalesDate. Detail data is all the data that is retrieved by the dataset query.
Click Run to preview the report.
3. Add a Sparkline
To add a sparkline chart to a table
Click Design to return to design view.
Select the Total column in your table.
Right-click, point to Insert Column, and then click Left.
In the new column, right-click in the [Product] row, point to the Insert ribbon tab, and then click Sparkline.
Make sure the first sparkline in the Column row is selected and then click OK.
Click the sparkline to show the Chart Data pane.
Click the plus (+) sign in the Values box, and then click Sales.
The values in the Sales field are now the values for the sparkline.
Click the plus (+) sign in the Category Groups box, and then click SalesDate.
Click Run to preview your report.
Note that there are sparkline charts in each row of the table, but they're not correct. The bars in the charts don't line up with each other. There are only four bars in the second row of data, so the bars are wider than the bars in the first row, which has six. You can't compare values for each product per day. They need to line up with each other.
Also note that for each row, the tallest bar for that row is the height of the row. This is misleading, too, because the largest values for each row are not equal: the largest value for Budget Movie-Maker is $10,400, but the largest value for Slim Digital is $26,576-more than twice as large. And yet the largest bars in those two rows are about the same height. That also needs to be made to scale with the other sparklines.
4. Align the Sparklines Vertically and Horizontally
The sparklines are hard to read when they don't all use the same measurements. Both the horizontal and vertical axes for each need to match the rest.
To set alignment for the sparklines in the table
Click Design to return to design view.
Right-click the sparkline and click Vertical Axis Properties.
Check the Align axes in check box.
Tablix1 is showing in the list. That is the only option. This sets the height of the bars in each sparkline relative to the others.
Click OK.
Right-click the sparkline and click Horizontal Axis Properties.
Check the Align axes in check box.
Tablix1 is showing in the list. That is the only option. This sets the width of the bars in each sparkline relative to the others. If some sparklines have fewer bars than others, then those sparklines will have blank spaces for the missing data.
Click OK.
Click Run to preview your report again.
Note that all the bars are now aligned with the bars in the other rows.
5. (Optional) Format Data as Currency
By default, the summary data for the Sales field displays a general number. Format it to display the number as currency. Toggle Placeholder Styles to display formatted text boxes and placeholder text as sample values.
To format a currency field
Click Design to switch to design view.
Click the cell in the second row (under the column headings row) in the SalesDate column and drag to select all cells that contain
[Sum(Sales)]
.On the Home tab, in the Number group, click the Currency button. The cells change to show the formatted currency.
If your regional setting is English (United States), the default sample text is [$12,345.00]. If you do not see an example currency value, click Placeholder Styles in the Numbers group, and then click Sample Values.
Click Run to preview your report.
The summary values for Sales display as currency.
6. (Optional) Format Data as Dates
By default, the SalesDate field displays both date and time information. You can format them to display only the date.
To format a date field as the default format
Click Design to return to design view.
Click the cell that contains
[SalesDate]
.On the Ribbon, on the Home tab, in the Number group, from the drop-down list, select Date.
The cell displays the example date [1/31/2000]. If you do not see an example date, click Placeholder Styles in the Numbers group, and then click Sample Values.
Click Run to preview the report.
The SalesDate values display in the default date format.
7. (Optional) Change Column Widths
By default, each cell in a table contains a text box. A text box expands vertically to accommodate text when the page is rendered. In the rendered report, each row expands to the height of the tallest rendered text box in the row. The height of the row on the design surface has no affect on the height of the row in the rendered report.
To reduce the amount of vertical space each row takes, expand the column width to accommodate the expected contents of the text boxes in the column on one line.
To change the width of columns
Click Design to return to design view.
Click the table so that column and row handles appear above and next to the table.
The gray bars along the top and side of the table are the column and row handles.
Point to the line between column handles so that the cursor changes into a double arrow. Drag the columns to the size you want. For example, expand the column for Product so that the product name displays on one line.
Click Run to preview your report.
8. (Optional) Add a Report Title
A report title appears at the top of the report. You can place the report title in a report header or if the report does not use one, in a text box at the top of the report body. In this tutorial, you will use the text box that is automatically placed at the top of the report body.
The text can be further enhanced by applying different font styles, sizes, and colors to phrases and individual characters of the text. For more information, see Format Text in a Text Box (Report Builder and SSRS).
To add a report title
On the design surface, click Click to add title.
Type Product Sales, and then click outside the text box.
Right-click the text box that contains Product Sales and click Text Box Properties.
In the Text Box Properties dialog box, click Font.
In the Size list, select 18pt.
In the Color list, select Maroon.
Select Bold.
Click OK.
9. Save the Report
Save the report to a report server or your computer. If you do not save the report to the report server, a number of Reporting Services features such as report parts and subreports are not available.
To save the report on a report server
From the Report Builder button, click Save As.
Click Recent Sites and Servers.
Select or type the name of the report server where you have permission to save reports.
The message "Connecting to report server" appears. When the connection is complete, you see the contents of the report folder that the report server administrator specified as the default location for reports.
In Name, replace the default name with Product Sales.
Click Save.
The report is saved to the report server. The name of report server that you are connected to appears in the status bar at the bottom of the window.
To save the report on your computer
From the Report Builder button, click Save As.
Click Desktop, My Documents, or My computer, and browse to the folder where you want to save the report.
In Name, replace the default name with Product Sales.
Click Save.
Next Steps
This concludes the tutorial for creating a table report with sparkline charts. For more information about sparklines, see Sparklines and Data Bars (Report Builder and SSRS).
See Also
Tutorials (Report Builder)
Report Builder in SQL Server 2014