Creating and Managing Datasets
When you create data components in a report, datasets are created. A dataset is the set of data built from the result of a query, stored procedure, imported SQL, imported APE, user defined data source, hierarchical data source or business view, and can optionally have filters applied to it. A dataset has a name, which by default is the name of the data resource on which it is created. A dataset built on data resource such as query, stored procedure, imported SQL, imported APE, UDS and HDS can contain all the DBFields in the data resource, as well as the parameters and valid formulas of these DBFields in the same catalog data source as the data resource; a dataset created from a business view can contain only view elements and dynamic resources.
Datasets in a page report created using query resources and web report can be shared by different data components. Having data components in the same report use an existing dataset whenever possible will have a dramatic effect on the performance of your reports in the runtime environment. This is because each dataset is created by running a query against the database, and that is the most expensive part of running a report in terms of execution time. Even when two datasets are based on the same query Logi JReport will still run the query separately for each dataset.
Below is a list of the sections covered in this topic:
- Creating Datasets in a Report
- Managing the Datasets in a Report
- Setting Properties of the Datasets in a Report
- Customizing Field Display Names for Datasets in a Report
Creating Datasets in a Report
You have the following methods to create datasets in a report:
- Creating a dataset from the report wizard
When you create a data component using the report wizard, a dataset is created at the same time, either empty or containing some data fields, depending on whether data fields are added to the data component.
- Creating a dataset via the Data panel
(available to page reports created using query resources only)
- In the Data panel, choose <Choose Data from...> from the dataset drop-down list.
- In the New Dataset dialog, specify the data resource in the current catalog on which the dataset will be built.
- Enter the name of the dataset in the New Dataset Name field.
- Select OK, and an empty dataset will be created.
- Creating a dataset from the Manage Datasets dialog
Note: If a dataset is created on a hierarchical data source, when you use the dataset to create data components, pay attention to the unique features of HDS.
Managing the Datasets in a Report
You can manage the datasets in a report with the Manage Datasets dialog, for example, you can add more data fields to the datasets, filter the datasets, rename the datasets, and so on. However this feature is supported only for query based page reports and library components.
To manage the datasets in a report, open the report, then select Report > Manage Datasets to display the Manage Datasets dialog.
You can manage the datasets in a report as follows:
- Creating a dataset
- Select the New button (the button is activated for page reports created using query resources only).
- In the New Dataset dialog, specify the data source on which the dataset will be built.
- Enter the name of the dataset in the New Dataset Name field.
- Select OK, and an empty dataset is created.
- Add data fields to the dataset as required.
- Adding/Removing data fields in a dataset
For any dataset, Logi JReport automatically adds fields to it when fields are added to the data components that use the dataset, and removes the fields from the dataset once you remove them from the data components that use it. So there generally is no need to ever add or remove fields from a dataset specifically. However in the Manage Datasets dialog, you can still manually add or remove data fields from a dataset. To do this, in the Dataset List box select the dataset you want to edit, then in the Data tab:- To add more data fields to the dataset, from the Available Resource box, select the fields from the source on which the dataset is created and then select to add them to the dataset. You can also select a field and drag and drop it into the Dataset box.
- To remove an unnecessary data field from the dataset, select it in the Dataset box and select . Only the fields which are not used by any data component created on the dataset, either directly or indirectly, can be removed. To remove all the data fields in a dataset, select , however when you select the button, only the unused data fields will actually be removed. When you enter the dialog the next time, you will find that the data fields used by data components created on the dataset will still display in the Dataset box.
- Use and to adjust the order of the added fields in the Dataset box.
- Filtering data fields in a dataset
- In the Dataset List box select the dataset you want to filter, then select the Filter tab.
- If the dataset is created on a business view, the Filter drop-down list is available, listing all the predefined filters of the business view. You can select one from the drop-down list to apply to the dataset, or select User Defined in the list to define a new filter as required.
- Add the filter conditions as required. Based on the data resource type from which the dataset is created, a business view or a query resource, the way to create a filter for the dataset differs.
If the dataset is created on a business view, you can add filter condition for it in the same way as you add conditions for a predefined filter in the business view.
To add filter conditions for a dataset created from a query resource:
- Select the Add Condition button to add a condition line.
- From the field drop-down list, select the field to be filtered. The field can be any DBField in the query resource, or a parameter or valid formula of these DBFields in the same catalog data source as the query resource.
- From the operator drop-down list, set the operator with which to compose the filter expression.
- In the value text box, select to specify the value of how to filter the field in the Expressions dialog or input the value manually. You can also use the special field User Name or a parameter to filter the dataset dynamically. For the usage of parameters in filter conditions, see the example in Dynamically filtering queries.
When you type in the value, if multiple values are required, they should be separated with ",", and if "," or "\" is contained in the values, write it as "\," or "\\".
- Select Add Condition to add more condition lines and define the logic (And or Or) between the condition lines.
To group some condition lines, select them and select the Group button, then the selected condition lines will be added in one group and work as one line of filter expression. Conditions and groups together can be further grouped. To take any condition or group in a group out, select it and select Ungroup.
To adjust the priority of the condition lines, select it and select the Up or Down button.
To delete a condition line, select it and select the Delete button.
Tips:
- A dataset is created based on another data resource and the data resource itself can also be applied with a filter. You may want to know the differences between the filters. Select here for details.
- You can also add/remove the data fields in a dataset or filter a dataset while creating a data component using a query resource with the report wizard. To do this, select the More Options button and check the Existing Dataset radio button in the Data screen of the wizard, then select an existing dataset and select the Edit button. In the Dataset Editor, edit the dataset as required.
- A dataset created from a query resource can also be filtered by selecting the Dataset Filter button on the toolbar of the Data panel.
Note: The following SQL type of data cannot be filtered: Db.SQL_BINARY, Db.SQL_BLOB, Db.SQL_CLOB, Db.SQL_LONGVARCHAR, Db.SQL_LONGVARBINARY, Db.SQL_VARBINARY and Db.SQL_OTHER.
- Optimizing a dataset
You can enlarge or decrease the scope of retrieved data for a dataset, and therefore make a balanceable decision between better performance and special usage cases/demands. However, this feature is not supported on datasets created from business views so only works for page reports that are created using query resources. For datasets created on business views, you can make use of the Prefetch property on the business views.- In the Dataset List box select the dataset with the name you want to optimize.
- Select the Optimize Dataset button. The Optimize Dataset dialog appears.
- Choose a retrieved data scope for the dataset.
- Only Columns Used in Report
Only data columns used in the current report are retrieved at runtime. This way ensures the best performance since the least data is retrieved. This is always the default for page reports. - All Columns in Dataset
All data columns defined in the dataset are retrieved at runtime. Unless you manually added columns to the dataset, this is the same as Only Columns Used in Report. - All Columns in Query
All data columns in the query that the dataset is based on are retrieved at runtime. This usually leads to lower performance and is not of any benefit unless you expect the users to often need to add more columns to the report.
- Only Columns Used in Report
- Select OK to optimize the dataset.
- Renaming a dataset
- In the Dataset List box select the dataset with the name you want to modify.
- Double-click in the Name text box of the dataset.
- Input a new name in the text box and press Enter to apply the changes.
However, you should not rename a dataset that has been used by any data component. Renaming a referenced dataset will cause data components based on the dataset unable to work anymore.
- Removing a dataset
- In the Dataset List box select the dataset you want to remove.
- Select the Remove button to remove the specified dataset.
- Select OK to apply the change and close the dialog.
However, if you remove a dataset directly in this way, any data components created based on the dataset will not work. So when you want to remove a dataset, it is recommended that you first remove the data components which reference this dataset.
Setting Properties of the Datasets in a Report
Each dataset in a query based page report and library component has its own node in the Report Inspector. You can edit the properties there to make the dataset better serve the data components created on it.
To edit properties of a dataset in a report:
- In the Report Inspector, select the name of the dataset under the Datasets node for a page report or Data Source node for a library component.
- In the Properties sheet, edit the properties of the dataset as required.
For example, you can apply a cached query result file to the dataset, specify the data buffer size for the dataset to improve performance, apply record level security for the data components using the dataset.
Customizing Field Display Names for Datasets in a Report
For datasets created on query resources in a page report, Logi JReport allows you to customize the display names of the data fields in the datasets, so that when end users run the page report in Page Report Studio and perform operations such as Sort, Filter on data components in the page report, they will be able to work with intuitive field names. You can also specify the actions in which the customized display names will participate for each data component in the page report.
- Open the page report that is created using query resources.
- Select Report > Edit Display Name to display the Edit Display Name dialog.
- From the Report Dataset drop-down list, where all datasets used in the page report are listed, select a dataset and all the data fields in the dataset are then shown in the mapping name box.
- To make the resource names sort automatically, check the Auto Sort checkbox.
- Specify the display names for the data fields in the Display Name column. A formula can be selected as the display name of the data field.
- Select another dataset and repeat the above steps to edit the display names of data fields in it.
- If required, you can select the Advanced button to further customize the display names for data components in the page report using the Edit Display Name for Component dialog.
- From the Component drop-down list, select the data component in the page report you want to customize.
Tip: You can also right-click a data component created using query resource in a page report and then select Edit Display Name from the shortcut menu to display the Edit Display Name for Component dialog. However, if the dialog is opened in this way, only the component you right-click on will be listed in the Component drop-down list.
- In the action columns, check the corresponding checkboxes to indicate whether the actions are enabled for the data fields. Check the checkbox on the action column header if you want the corresponding action to be enabled for all data fields. If any action is not supported on the selected data component, the corresponding column will be disabled.
When an action is checked for a data field, the field's display name instead of mapping name will be shown in the corresponding dialog or submenu in Page Report Studio. If you uncheck the box for any field in any action column, the field will not be available for the action. Moreover, if you set the display name of any field to be blank in the Edit Display Name dialog, all actions will be disabled for the field, which means end users will not be able to perform all these actions on the field in Page Report Studio.
- Upon finishing, select OK to accept the changes.
Note: If you set the display name of any data field to be blank, the field will not be shown in the lists where display names are displayed in Page Report Studio.