Discover how a bimodal integration strategy can address the major data management challenges facing your organization today.
Get the Report →Build an OLAP Cube in SSAS from Zuora Data
Establish a connection to Zuora data data from SQL Server Analysis Services, and use the Zuora Data Provider to build OLAP cubes for use in analytics and reporting.
SQL Server Analysis Services (SSAS) serves as an analytical data engine employed in decision support and business analytics, offering high-level semantic data models for business reports and client applications like Power BI, Excel, Reporting Services reports, and various data visualization tools. When coupled with the CData ADO.NET Provider for Zuora, you gain the capability to generate cubes from Zuora data, facilitating more profound and efficient data analysis.
In this article, we will guide you through the process of developing and deploying a multi-dimensional model of Zuora data by creating an Analysis Services project in Visual Studio. To proceed, ensure that you have an accessible SSAS instance and have installed the ADO.NET Provider.
Creating a Data Source for Zuora
Start by creating a new Analysis Service Multidimensional and Data Mining Project in Visual Studio. Next, create a Data Source for Zuora data in the project.
- In the Solution Explorer, right-click Data Source and select New Data Source.
- Opt to create a data source based on an existing or new connection and click New.
- In the Connection Manager, select CData ADO.NET Provider for Zuora, enter the necessary connection properties, and click Next.
Zuora uses the OAuth standard to authenticate users. See the online Help documentation for a full OAuth authentication guide.
Configuring Tenant property
In order to create a valid connection with the provider you need to choose one of the Tenant values (USProduction by default) which matches your account configuration. The following is a list with the available options:
- USProduction: Requests sent to https://rest.zuora.com.
- USAPISandbox: Requests sent to https://rest.apisandbox.zuora.com"
- USPerformanceTest: Requests sent to https://rest.pt1.zuora.com"
- EUProduction: Requests sent to https://rest.eu.zuora.com"
- EUSandbox: Requests sent to https://rest.sandbox.eu.zuora.com"
Selecting a Zuora Service
Two Zuora services are available: Data Query and AQuA API. By default ZuoraService is set to AQuADataExport.
DataQuery
The Data Query feature enables you to export data from your Zuora tenant by performing asynchronous, read-only SQL queries. We recommend to use this service for quick lightweight SQL queries.
Limitations- The maximum number of input records per table after filters have been applied: 1,000,000
- The maximum number of output records: 100,000
- The maximum number of simultaneous queries submitted for execution per tenant: 5
- The maximum number of queued queries submitted for execution after reaching the limitation of simultaneous queries per tenant: 10
- The maximum processing time for each query in hours: 1
- The maximum size of memory allocated to each query in GB: 2
- The maximum number of indices when using Index Join, in other words, the maximum number of records being returned by the left table based on the unique value used in the WHERE clause when using Index Join: 20,000
AQuADataExport
AQuA API export is designed to export all the records for all the objects ( tables ). AQuA query jobs have the following limitations:
Limitations- If a query in an AQuA job is executed longer than 8 hours, this job will be killed automatically.
- The killed AQuA job can be retried three times before returned as failed.
When you configure the connection, you may also want to set the Max Rows connection property. This will limit the number of rows returned, which is especially helpful for improving performance when designing reports and visualizations.
- Set the impersonation method to Inherit and click Next.
- Name the data source (CData Zuora Source) and click Finish.
Creating a Data Source View
After you create the data source, create the data source view.
- In the Solution Explorer, right-click Data Source Views and select New Data Source View.
- Select the data source you just created (CData Zuora Source) and click Next.
- Choose a foreign key match pattern that matches your underlying data source and click Next.
- Select Zuora tables to add to the view and click Next.
- Name the view and click Finish
Based on the foreign key match scheme, relationships in the underlying data will be automatically detected. You can view (and edit) these relationships by double clicking Data Source View.
Note that adding a secondary data source to the Data Source View is not supported. When working with multiple data sources, SSAS requires both sources to support remote queries via OpenRowset which is unavailable in the ADO.NET Provider.
Creating a Cube for Zuora
The last step before you can process the project and deploy Zuora data to SSAS is creating the cubes.
- In the Solution Explorer, right-click Cubes and select New Cube
- Select "Use existing tables" and click Next.
- Select the tables that will be used for measure group tables and click Next.
- Select the measures you want to include in the cube and click Next.
- Select the dimensions to be created, based on the available tables, and click Next.
- Review all of your selections and click Finish.
Process the Project
With the data source, data source view, and cube created, you are ready to deploy the cube to SSAS. To configure the target server and database, right-click the project and select properties. Navigate to deployment and configure the Server and Database properties in the Target section.
After configuring the target server and database, right-click the project and select Process. You may need to build and deploy the project as a part of this step. Once the project is built and deployed, click Run in the Process Database wizard.
Now you have an OLAP cube for Zuora data in your SSAS instance, ready to be analyzed, reported, and viewed. Get started with a free, 30-day trial of the CData ADO.NET Provider for Zuora.