Analyze Live SQL Analysis Services Data in SAS Viya

Dibyendu Datta
Dibyendu Datta
Lead Technology Evangelist
Use CData Connect AI to connect to SQL Analysis Services data from SAS Viya and deploy self-service analytics using live SQL Analysis Services data.

SAS Viya is an analytics platform that enhances data management, machine learning, and analytics, fostering efficient decision-making and insights. When paired with CData Connect AI, you get instant, cloud-to-cloud access to SQL Analysis Services data for building predictive models, crafting stunning insights to make data-driven decisions, and more. This article shows how to connect to Connect AI from the SAS Viya cloud platform and integrate live SQL Analysis Services data into your self-service AI and analytics deployments.

CData Connect AI provides a pure SQL, cloud-to-cloud interface for SQL Analysis Services, allowing you to easily integrate with live SQL Analysis Services data in SAS Viya — without replicating the data. CData Connect AI looks exactly like a SQL Server database to SAS Viya and uses optimized data processing out of the box to push all supported SQL operations (filters, JOINs, etc.) directly to SQL Analysis Services, leveraging server-side processing to return SQL Analysis Services data quickly.

Configure SQL Analysis Services Connectivity for SAS Viya

Connectivity to SQL Analysis Services from SAS Viya is made possible through CData Connect AI. To work with SQL Analysis Services data from SAS Viya, we start by creating and configuring a SQL Analysis Services connection.

  1. Log into Connect AI, click Sources, and then click Add Connection
  2. Select "SQL Analysis Services" from the Add Connection panel
  3. Enter the necessary authentication properties to connect to SQL Analysis Services.

    To connect, provide authentication and set the Url property to a valid SQL Server Analysis Services endpoint. You can connect to SQL Server Analysis Services instances hosted over HTTP with XMLA access. See the Microsoft documentation to configure HTTP access to SQL Server Analysis Services.

    To secure connections and authenticate, set the corresponding connection properties, below. The data provider supports the major authentication schemes, including HTTP and Windows, as well as SSL/TLS.

    • HTTP Authentication

      Set AuthScheme to "Basic" or "Digest" and set User and Password. Specify other authentication values in CustomHeaders.

    • Windows (NTLM)

      Set the Windows User and Password and set AuthScheme to "NTLM".

    • Kerberos and Kerberos Delegation

      To authenticate with Kerberos, set AuthScheme to NEGOTIATE. To use Kerberos delegation, set AuthScheme to KERBEROSDELEGATION. If needed, provide the User, Password, and KerberosSPN. By default, the data provider attempts to communicate with the SPN at the specified Url.

    • SSL/TLS:

      By default, the data provider attempts to negotiate SSL/TLS by checking the server's certificate against the system's trusted certificate store. To specify another certificate, see the SSLServerCert property for the available formats.

    You can then access any cube as a relational table: When you connect the data provider retrieves SSAS metadata and dynamically updates the table schemas. Instead of retrieving metadata every connection, you can set the CacheLocation property to automatically cache to a simple file-based store.

    See the Getting Started section of the CData documentation, under Retrieving Analysis Services Data, to execute SQL-92 queries to the cubes.

  4. Click Save & Test
  5. Navigate to the Permissions tab in the Add SQL Analysis Services Connection page and update the User-based permissions.

Add a Personal Access Token

When connecting to Connect AI through the REST API, the OData API, or the Virtual SQL Server, a Personal Access Token (PAT) is used to authenticate the connection to Connect AI. It is best practice to create a separate PAT for each service to maintain granularity of access.

  1. Click on the Gear icon () at the top right of the Connect AI app to open the settings page.
  2. On the Settings page, go to the Access Tokens section and click Create PAT.
  3. Give the PAT a name and click Create.
  4. The personal access token is only visible at creation, so be sure to copy it and store it securely for future use.

With the connection configured and a PAT generated, you are ready to connect to SQL Analysis Services data from SAS Viya.

Connecting to CData Connect AI from SAS Viya

The following steps detail the process of loading data from SQL Analysis Services into SAS Viya using the established connection in CData Connect AI.

  1. Download and install the CData Connect AI JDBC driver.
    • Open the Integrations page of CData Connect AI.
    • Search for and select JDBC.
    • Download and run the setup file.
    • When the installation is complete, the JAR file can be found in the installation directory (inside the lib folder).
  2. Now, log in to SAS Viya and navigate to the Applications Menu at the top-left corner.
  3. Select Develop Code and Flows from the Analytics Life Cycle topic.
  4. Navigate to the Explorer tab and click on SAS Server on the left panel.
  5. Follow the steps to upload the JAR file of the CData Connect JDBC driver:
    • Right-click on the "Home" directory.
    • Click on Upload files.
    • Place the JAR file in the specified location and note its file path.
  6. Once done, navigate to the Libraries tab and click on Create a new library connection (on the top left corner as shown below) for the CData Connect JDBC.
  7. Enter the library connection settings:
    • Connection name: enter a name for your connection
    • Library name (libref): enter a reference for your library
    • Library type: choose "SAS/ACCESS to JDBC"
  8. Click on the Properties tab and set Library attributes to READONLY.
  9. Click the Connection Options tab and enter the following details:
    • Hive JDBC driver's class name: cdata.jdbc.connect.ConnectDriver
    • Java CLASSPATH: enter the file path to the JAR driver file (Refer to Step 5)
  10. Click on Test connection. If it succeeds, click on Save and connect.
  11. Click on to add a new tab and select SAS program.
  12. Fill in the code block below with your setup parameters:
    • Libref: enter the library reference you defined in Step 9.
    • ClassPath: enter the file path to the JAR driver file.
    • Username: enter your CData Connect username. This is displayed in the top-right corner of the CData Connect interface. For example, [email protected].
    • DefaultCatalog: enter the connection configured in CData Connect AI that you want to query.
    • Password: enter the PAT you generated in the "Add a Personal Access Token" section.
    libname [Libref] JDBC   
    classpath=[ClassPath]  
    class="cdata.jdbc.connect.ConnectDriver"     
    URL="jdbc:Connect:AuthScheme=Basic;User=[Username];DefaultCatalog=[DefaultCatalog];DefaultSchema=dbo;Password=[PAT]"; 
     
    proc sql; 
    
    SELECT * FROM [Libref].MyTable; 
    
    quit; 
    
  13. Click on Run. You can see the data load from CData Connect AI into SAS Viya.

Live Access to SQL Analysis Services Data from Cloud Applications

At this point, you have a direct, cloud-to-cloud connection to SQL Analysis Services data from SAS Viya. You can build predictive models, craft insights to make data-driven decisions, and more — all without replicating SQL Analysis Services data.

Try Connect AI and get real-time data access to hundreds of SaaS, Big Data, and NoSQL sources directly from your cloud applications.

Ready to get started?

Learn more about CData Connect AI or sign up for free trial access:

Free Trial