Filter, group, and sort data in Report Builder paginated reports
Applies to: Microsoft Report Builder (SSRS) Power BI Report Builder Report Designer in SQL Server Data Tools
In a paginated report, expressions are used to help control, organize, and sort report data. By default, as you create datasets and design the report layout, properties of report items are set automatically to expressions. This behavior is based on the dataset fields, parameters, and other items that appear in the Report Data pane. You can also add an interactive sort button to a table or matrix cell to let a user interactively change the row sort order for groups or rows within groups.
Filter expressions: A filter expression tests data for inclusion or exclusion based on a comparison that you specify. Filters are applied to data in a report after the data is retrieved from a data connection. You can add any combination of filters to the following items:
- Shared dataset definition on the report server.
- Shared dataset instance or embedded dataset in a report.
- Data region, such as a table or a chart.
- Data region group, such as a row group in a table or a category group in a chart.
Group expressions: A group expression organizes data based on a dataset field or other value. Group expressions are created automatically as you build the report layout. The report processor evaluates group expressions after filters are applied to the data and as report data and data regions are combined. You can customize a group expression after you create it.
Sort expressions: A sort expression controls the order in which data appears in a data region. Sort expressions are created automatically as you build the report layout. By default, a sort expression for a group is set to the same value as the group expression. You can customize a sort expression after you create it.
Interactive sort: To enable a user to sort or reverse the sort order of a column, you can add an interactive sort button to a column header or group header cell in a table or matrix.
To help your users customize filter, group, or sort expressions, you can change an expression to add a reference to a report parameter. For more information, see Paginated report parameters (Report Builder).
For more information and examples, see the following articles:
Group expression examples in paginated reports (Report Builder)
Filter equation examples in a paginated report (Report Builder)
Note
You can create and modify paginated report definition (.rdl) files in Microsoft Report Builder, Power BI Report Builder, and in Report Designer in SQL Server Data Tools.
Filter data in a report
Filters are parts of a report that help control report data after it gets retrieved from the data connection. Use filters when you can't change a dataset query to filter data before it gets retrieved from an external data source.
When it's possible, build dataset queries that return only the data that you need to display in the report. When you reduce the amount of the data that must be retrieved and processed, you're helping to improve report performance. For more information, see Report embedded datasets and shared datasets (Report Builder and SSRS).
After the data is retrieved from the external data source, you can add filters to:
- Datasets.
- Data regions.
- Data region groups, including detail groups.
Filters are applied at run time first on the dataset, and then it proceeds to the data region. Then the filter is applied to the group, in top-down order for group hierarchies. In a table, matrix, or list, filters for row groups, column groups, and adjacent groups are applied independently. In a chart, filters for category groups and series groups are applied independently. For more information, see Add dataset filters, data region filters, and group filters to a paginated report (Report Builder).
For each filter, you specify a filter equation. A filter equation includes three elements:
- Dataset field or expression that specifies the data to filter.
- Operator.
- Value to compare.
Only data values that match the filter condition are included when the item is processed.
To help your users control the data in a report, you can include parameters in filter expressions. For more information, see Parameters collection references in a paginated report (Report Builder).
To customize a view for each user, you can include a reference to the built-in field UserID in a filter. For more information, see Built-in Globals and User references in a paginated report (Report Builder).
Group data in a report
Groups organize data in a report for display or for calculating aggregate values. Understanding how to define groups and use group features helps you to design reports that are more concise.
Group expressions are created automatically when you:
- Arrange dataset fields in the Table, Matrix, Chart wizard or match fields in the Map wizard.
- In a table, matrix, or list, add a field to the Row Groups or Column Groups area in the Grouping pane.
- In a chart, add a field to the Category Groups or Series Groups area in the Chart data pane.
- In a map, specify a field to match map elements with analytical data in the Layer Data context menu item.
A group is a part of the report definition. Each group has a name. By default, the group name is based on the dataset field that it comes from.
In a table or matrix data region, you can create multiple row groups and column groups. You can display your data in a visual hierarchy by organizing nested groups, adjacent groups, and recursive hierarchy groups (such as an organizational chart).
The group name identifies an expression scope. You can specify the name of a group as a scope in which to:
- Calculate aggregates.
- Organize data hierarchically and toggle the display of child nodes from parent nodes in a drilldown report.
- Display different views of the same data on multiple data regions.
- Visualize summary data in a table, matrix, chart, gauge, or map.
For more information, see Expression scope for totals, aggregates, and built-in collections in a paginated report (Report Builder).
To group on several dataset fields, add each field to the set of group expressions. You can also write your own group expressions in Microsoft Visual Basic. For example, you can group by a range of values, or by using a report parameter to give users the option to select how to group data in a data region. For more information, see Group expression examples in paginated reports (Report Builder).
To reduce the amount of data on each page and help you manage performance for report presentation, you can add page breaks before and after each group or each group instance. For more information, see Add a page break to a paginated report (Report Builder).
Creating data region groups is one way to organize data in a report. There are several other ways to organize data, each with its own advantages. For more information, see Drillthrough, drilldown, subreports, and nested data regions in a paginated report (Report Builder).
Define group variables
When you define a group, you can create a group variable to use in expressions that are scoped to the group and accessed from nested groups. A group variable is calculated once per group instance, and you can access them from expressions in child groups. For example, for data grouped by region and subregion, you can calculate a tax for each region and use that tax in calculations from the subregion group.
For more information, see Report and group variables references in a paginated report (Report Builder) and Expression scope for totals, aggregates, and built-in collections in a paginated report (Report Builder).
Groups and scope in data regions
To provide multiple views of data from the same dataset, you can specify the same group expressions for each data region. For example, you can display categorized data in a table to show all detail data and in a pie chart to show aggregates and to help visualize each category in relation to the entire dataset. For more information, see Link multiple data regions to the same dataset in a paginated report (Report Builder).
When you nest a data region in a cell in a table, matrix, or list, you're automatically scoping the data to the innermost group memberships of the cell. For example, assume that you add a chart to a cell that is in both a row group and a column group. The data available to that chart is scoped to the innermost row group instance and innermost column group instance at run time. For more information, see Expression scope for totals, aggregates, and built-in collections in a paginated report (Report Builder).
Sort data in a report
To control the sort order of data in your report, you can sort data in a dataset query, or define a sort expression for a data region or group. You can also add interactive sort buttons to tables and matrices to enable a user to change the sort order for rows.
All three types of sorts can be combined in the same report. By default, sort order gets determined by the order in which data returns by the dataset query. Sort expressions are applied in the data region and data region group. Interactive sorts are applied after sort expressions.
For expressions that contain aggregate functions, sort order doesn't affect most results. Sort order affects return values for the following aggregate functions: First, Last, and Previous. For more information, see Report Builder functions - aggregate functions reference in paginated reports (Report Builder).
Sort data in a dataset query
To presort data before it gets retrieved for a report, include sort order in the dataset query. By sorting data in the query, the sorting work is done by the data source instead of the report processor.
For a Microsoft SQL Server data source type, you can add an ORDER BY clause to the dataset query. For example, the following Transact-SQL query sorts the columns Sales and Region by Sales in descending order from the table SalesOrders: SELECT Sales, Region FROM SalesOrders ORDER BY Sales DESC
.
Note
Not all data sources support the ability to specify sort order in the query.
Sort data with sort expressions
To sort data in the report after it gets retrieved from the data source, you can set sort expressions on a Tablix data region or a group, including the Details group. The following list describes the effect of setting sort expressions on different items:
Tablix data region: Set sort expressions on a table, matrix, or list data region to control the sort order of data in the data region, after dataset filters and data region filters are applied at run time.
Tablix data region group: Set sort expressions for each group, including the Details group, to control the sort order of group instances. For example, in the Details group, you control the order of the detail rows. For a child group, you control the order of group instances for the child group within the parent group. By default, when you create a group, the sort expression is set to the group expression and to ascending order.
If you have only one Details group, you can define a sort expression in the query, on the data region, or on the Details group to the same effect.
Chart data region: Set a sort expression for the category and series groups to control the sort order for data points. By default, the order of data points is also the order of the colors in the chart legend. For more information, see Format series colors on a paginated report chart (Report Builder).
Map report item: You don't typically need to sort data for a map data region because the map groups data to display on map elements.
Gauge data region: You don't typically need to sort data for a gauge data region because the gauge displays a single value relative to a range. If you do need sort data in a gauge, you must first define a group, and then set a sort expression for the group.
Sort by a different value
You can sort the rows in a data region by a value other than the field value. For example, suppose that the field Size contains text values that correspond to small, medium, large, and extra large. By default, the sort expression for a row group based on Size is also called [Size]
. To have more control over your sorted data, you can add a field to the dataset query that defines the sort order that you want.
Alternatively, you can define a dataset that includes only the sizes and a value that specifies the order that you want. You can change the sort expression to use the Lookup function for the sort order value.
For example, assume that the following Transact-SQL query defines a dataset named Sizes. The query uses a CASE statement to define a sort order value SizeSortOrder for each value of Size
:
SELECT Size,
CASE Size
WHEN 'S' THEN 1
WHEN 'M' THEN 2
WHEN 'L' THEN 3
WHEN 'XL' THEN 4
ELSE 0
END as SizeSortOrder
FROM Production.Product
In a table that has a row group based on Size, you can change the group sort expression to use a Lookup function to find the numeric field that corresponds to the size value. The expression would be similar to this example:
=Lookup(Fields!Size.Value, Fields!Size.Value, Fields!SizeSortOrder.Value, "Sizes")
For more information, see Sort data in a data region in a paginated report (Report Builder) and Report Builder functions - Lookup function in a paginated report (Report Builder).
Add interactive sorting for the user
To enable a user to change the sort order of report data in a table or matrix, you can add interactive sort buttons to column headers or group headers. Users can select the button to toggle the sort order. Interactive sort is supported in rendering formats that allow user interaction, such as HTML.
You add interactive sort buttons to a text box in a tablix data region cell. By default, every cell contains a text box. In the text box properties, you specify which part of a table or matrix data region to sort (the parent group values, the child group values, or the detail rows). You specify what to sort by and whether to apply the sort expression to other report items that have a peer relationship. For example, if a table and a chart that provide views on the same dataset are contained in a rectangle, they're peer data regions. When a user toggles the sort order in the table, the sort order for the chart also toggles. For more information, see Interactive sort in a paginated report (Report Builder).
How-to topics
Keep Headers Visible When Scrolling Through a Report (Report Builder and SSRS)
Display Headers and Footers with a Group (Report Builder and SSRS)
Add Interactive Sort to a Table or Matrix (Report Builder and SSRS)
Set a No Data Message for a Data Region (Report Builder and SSRS)
Create a Recursive Hierarchy Group (Report Builder and SSRS)
Add or Delete a Group in a Data Region (Report Builder and SSRS)
Display Headers and Footers with a Group (Report Builder and SSRS)
Add a Total to a Group or Tablix Data Region (Report Builder and SSRS)
Add Dataset Filters, Data Region Filters, and Group Filters (Report Builder and SSRS)
Create recursive hierarchy groups in a paginated report (Report Builder)
Display a Series with Multiple Data Ranges on a Chart (Report Builder and SSRS)