| title | Snowflake Semantic Views Integration |
|---|---|
| sidebarTitle | Snowflake Semantic Views |
| description | Snowflake Semantic Views integration is available in Cube on the Enterprise plan. |
Snowflake Semantic Views integration is available in Cube on the Enterprise plan.
Cube supports bi-directional integration with Snowflake Semantic Views. This integration enables you to author views in Cube and use them in Snowflake, or work with Snowflake semantic views directly in Cube. This ensures consistency between your Cube definitions and Snowflake's semantic layer, allowing teams to work in their preferred environment.
The Snowflake Semantic Views integration provides two-way synchronization between Cube and Snowflake:
- Pull integration: Pull semantic views from Snowflake and turn them into cubes and views in Cube
- Push integration: Push Cube views into Snowflake as native semantic views
This bi-directional approach ensures that your semantic layer definitions remain consistent across both platforms, regardless of where they are authored.
From the IDE, users can pull semantic views from Snowflake and turn them into cubes and views in Cube. The pull integration generates code files with cube and view definitions in your Cube repository, making it easy to work with existing Snowflake semantic views.
- Connect to your Snowflake account from the Cube IDE
- Browse available semantic views in Snowflake
- Select the semantic views you want to import
- Cube generates the corresponding cube and view definitions
- The generated code files are added to your Cube repository
This allows you to leverage existing Snowflake semantic views in Cube without manual conversion, ensuring consistency between your Snowflake and Cube definitions.
Alternatively, you can push Cube views into Snowflake as native semantic views. The push integration creates DDL from Cube's definitions and executes it in Snowflake, creating Snowflake Semantic Views that match your Cube schema.
- Select Cube views you want to push to Snowflake
- Cube generates DDL statements from your Cube view definitions
- The DDL is executed in your Snowflake account
- Native Snowflake Semantic Views are created matching your Cube schema
This enables you to use Cube-authored views directly in Snowflake, maintaining consistency across both platforms.
The push integration uses the SQL Runner to execute DDL statements in Snowflake. To successfully create semantic views, ensure the following:
- Enable DDL operations for your Cube deployment. In the Cube Cloud UI, go to Deployment Settings → Configuration and turn on Enable DDL operations. Without this setting, the SQL Runner will reject the DDL statements that the push integration generates.
- The Snowflake role configured for your Cube data source (via
CUBEJS_DB_SNOWFLAKE_ROLE) has privileges to create semantic views in the target database and schema (CREATE SEMANTIC VIEWon the schema, plusUSAGEon the parent database and schema). - The role has
USAGEon the warehouse specified byCUBEJS_DB_SNOWFLAKE_WAREHOUSEandSELECTon the underlying tables referenced by the view. CUBEJS_DB_SNOWFLAKE_QUOTED_IDENTIFIERS_IGNORE_CASEis set consistently with how identifiers are defined in your Cube data model. The default value isfalse.
If a push fails with a permissions error, verify that Enable DDL operations is turned on in your deployment configuration and that the configured role has the required privileges listed above. See Snowflake data source configuration for the full list of relevant environment variables.
The Snowflake Semantic Views integration provides several advantages:
- Consistency: Keep your semantic layer definitions synchronized between Cube and Snowflake
- Flexibility: Work in your preferred environment—author in Cube or Snowflake
- Efficiency: Automatically generate definitions without manual conversion
- Collaboration: Enable teams to work in their preferred tools while maintaining consistency