Managing big data with on-demand apps
On-demand apps enable you to load and analyze big data sources in Qlik Sense Enterprise. Trying to analyze an entire big data store at one time is highly inefficient. Nevertheless, to make representative visualizations, all the data must be discoverable. Qlik Sense on-demand apps give users aggregate views of big data stores and allow them to identify and load relevant subsets of the data for detailed analysis.
On-demand apps expand the potential use cases for data discovery, enabling business users to conduct associative analysis on larger data sources. They allow users to first select data they are interested in discovering insights about and then interactively generate an on-demand app with which they can analyze the data with the full Qlik in-memory capabilities.
On-demand app components
Qlik Sense manages the loading of big data sources with selection apps that provide aggregated views of the big data and also enable a user to zoom in and analyze finer-grained data. Embedded in each selection app are on-demand app navigation links to one or more template apps used as the basis for creating on-demand apps. Properties of the navigation links and template apps enable you to tightly control the shape and volume of data loaded into on-demand apps.
Apps can be generated repeatedly from the template app to track frequently changing data sets. While the data is filtered according to selections made in the selection app, the on-demand app content is dynamically loaded from the underlying data source. The same on-demand app can be generated multiple times to make fresh analyses of the data as they change.
For more information, see Enabling on-demand app generation.
Constructing on-demand apps
Because on-demand selection and template apps require special load scripting, they are usually created by users with experience writing Qlik Sense load scripts. On-demand selection apps, for example, must load data with a modest level of dimension granularity. On-demand template apps contain load scripts with data binding expressions used to formulate the queries made on the data sources.
A selection app can be linked to multiple template apps, and a single template app can be linked to by multiple selection apps. But the template app's data binding expressions must correspond to fields in the selection apps that link to it. For that reason, selection and template apps tend to be created in conjunction with one another and often by the same experienced script writer.
Creating navigation links also requires an understanding of the fields in the selection app that have corresponding bindings in the template app. That is because each navigation link requires an expression that computes the total number of detail records. That total represents the aggregate records accessible by way of the selection state in the selection app. To create that expression requires that the user know how to compute the template app's total record count using fields available in the selection app.
For more information, see Building an on-demand app.
Using selection apps to generate on-demand apps does not require a user to understand the load script. Once an on-demand app navigation link has been created, a user can drag that navigation link onto the selection app's App navigation bar to create an app navigation point. On-demand apps are then generated from the navigation point.
Navigation points become available for on-demand app generation when the maximum row calculation from the expression in the navigation link comes within the required range. At that point, the user can generate an on-demand app. The user can also make another set of selections and generate additional apps based on those different selections.
For more information, see On-demand apps.
Navigation links have a limit on the number of on-demand apps that can be generated from the link. When the maximum number of apps has been generated, the user who is generating apps from the navigation point must delete one of the existing apps before generating a new on-demand app. The maximum number of generated apps applies to the on-demand app navigation link. If one on-demand app navigation point is created from the navigation link, then that navigation point would be able to create up to the maximum number. When multiple navigation points are created from the same navigation link, together those navigation points are limited to the maximum number set for the navigation link.
Navigation links also set a retention time for generated apps. On-demand apps are automatically deleted when their retention period expires.
Sharing on-demand apps
You can share on-demand selection apps in a shared or managed space. You must first make the sheets of the selection and template apps public. You can then add the selection app to a shared or managed space. If you are publishing to a managed space, you only need to publish the selection app.
Users with access to apps in those spaces can access the navigation points in those apps. For example, they can generate an on-demand app from the App navigation bar.
If your apps in managed or shared spaces contain sensitive data, use on-demand apps carefully and confirm the permissions of those who have access to your selection apps.
On-demand apps are added to users' personal spaces. If users have Can contribute, Can manage, Can publish, or Owner permissions in a shared or managed space, they can share their generated on-demand apps from their personal space with other users.
Once an on-demand selection app is published to a managed space, you cannot edit the navigation link in the selection app or published app. If you need to update the navigation link, delete the published app. Next, edit the link in the selection app, and publish the app again to the managed space.
Advantages of on-demand apps
On-demand apps help business users and IT departments derive value from big data environments in numerous ways. On-demand apps:
- Provide users with a "shopping list" experience that enables them to interactively populate their apps with a subset of data such as time period, customer segment, or geography.
-
Provide full Qlik Sense functionality on a latent subset that is hosted in memory.
- Enable IT to govern how large an app can be and invoke apps based on data volume or dimensional selections.
-
Provide access to non-SQL data sources such as Teradata Aster, MapR, SAP BEx, and the PLACEHOLDER function in SAP HANA.
- Allow customizable SQL and load script generation.
- Allow section access in all cases.
Limitations
On-demand apps have the following limitations:
-
The maximum amount of data that can be sent to an on-demand app is 50 MB. Any amount larger than that causes the on-demand app to fail without an error message. Set maximum row counts to ensure that users cannot create selections larger than 50 MB.
-
Once an on-demand selection app is published to a managed space, you cannot edit the navigation link in the selection app or published app. If you need to update the navigation link, delete the published app. Next, edit the link in the selection app, and publish the app again to the managed space.
-
If you change the script of your template app and insert a new binding variable, new on-demand app navigation links must be created to replace any existing app navigation links. If you do not, the selection for the corresponding field will not be sent for existing on-demand apps using that template app.