Snowflake
Snowflake Connection
Available when using an authoring Data Collector version 4.0.0 or later.
- Data Collector 5.4.0 or later - Requires the Snowflake stage library,
streamsets-datacollector-sdc-snowflake-lib
. - Data Collector
4.0.0 to 5.3.x - Requires
version 1.7.x or later of the Snowflake Enterprise stage library,
streamsets-datacollector-snowflake-lib
.
For a description of the Snowflake connection properties, see Snowflake Connection Properties.
Engine | Stage or Pipeline |
---|---|
Data Collector 5.6.0 or later |
|
Data Collector 4.0.0 or later |
|
Transformer 4.0.0 or later |
|
Transformer for Snowflake 5.0.0 or later |
|
For information about features added to the connection with different engine releases, see the connection requirements for the engine.
Snowflake Roles and Privileges
When you configure Transformer for Snowflake pipelines or Snowflake stages in Data Collector or Transformer pipelines, the associated Snowflake role must include all of the privileges required to perform the necessary Snowflake tasks.
For example, in Transformer for Snowflake pipelines, the specified role determines the Snowflake objects that can be used and the tasks that can be performed, such as writing to a table or using an email notification integration.
Using Custom Roles
- Assign the custom role as the default role (Data Collector/Transformer only)
- When using Snowflake stages in Data Collector or Transformer pipelines, in your Snowflake account, you can assign the custom role as the default role for the Snowflake user account specified in the Snowflake connection.
- Configure the connection to use a specified role
- Specify the name of the custom role in the Role property of the Snowflake connection.
Snowflake Connection Properties
When creating a Snowflake connection, configure the following properties on the Snowflake Connection Info tab:
allowUnderscoresInHost
driver property to
true
. For more information and alternate solutions, see
this Snowflake community
article.Snowflake Connection Info Property | Description |
---|---|
Custom Snowflake URL | Custom JDBC URL to use when using a virtual private Snowflake installation. |
Include Organization | Enables specifying the Snowflake
organization. Available with Snowflake Enterprise stage library 1.12.0 or later. |
Organization | Snowflake organization. Available with Snowflake Enterprise stage library 1.12.0 or later. |
Snowflake Region | Region where the Snowflake warehouse is located. Select one of the
following:
Available when Include Organization is disabled. |
Custom Snowflake Region | Custom Snowflake region. Available when using Other as the Snowflake region. |
Account | Snowflake account name. |
Authentication Method |
Authentication method to connect to Snowflake:
This property is available with authoring Data Collector 5.6.0 or later. |
User | Snowflake user name. The user account or the custom role that overrides the default role for this user account must have the required Snowflake privileges. The required privileges depend on where you use the connection. For details, see Snowflake Roles and Privileges. |
Password | Snowflake password. Required when using User Credentials authentication. |
Private Key Path | Path to the private key file. Required when using Key Pair Path authentication. |
Private Key Content | Contents of the private key file. Required when using Key Pair Content authentication. |
Private Key Password | Optional password for the specified private key file or content. Use
for encrypted private keys. Available when using Key Pair Path or Key Pair Content authentication. |
OAuth Token | OAuth token to use. You can use a Snowflake
security integration access token, refresh token, or code
grant. Required when using OAuth authentication. |
OAuth Client ID | Client ID for Snowflake security integration access
tokens. Available when using OAuth authentication. |
OAuth Client Secret | Client secret for Snowflake security integration access
tokens. Available when using OAuth authentication. |
OAuth Redirect URI | Redirect URI for Snowflake security integration access
tokens. Available when using OAuth authentication. |
Role | For connections used with Transformer for Snowflake, this property defines the role used with the pipeline. You
can override this role in pipeline properties as needed.
For connections used in Snowflake stages in Data Collector or Transformer pipelines, this role overrides the default role for the user account specified in the connection. You cannot override this role in Snowflake stages. Note: The custom
role must have the required Snowflake privileges, which are
dependent on the stage where you use the
connection. For details, see Snowflake Roles and Privileges. |
Warehouse | Optional default Snowflake warehouse to use. You can override this property in the pipeline or stage where you use the connection. Available with authoring Data Collector 5.10.0 or later. |
Database | Optional default Snowflake database to use. You can override this property in the pipeline or stage where you use the connection. Available with authoring Data Collector 5.10.0 or later. |
Schema | Optional default schema to use. You can override this property in the pipeline or stage where you use the connection. Available with authoring Data Collector 5.10.0 or later. |
Use Private Link Snowflake URL | Enables using a
private link URL. You can specify the URL in the Custom JDBC URL property above. Or, you can define the appropriate values for the Account property and either the Snowflake Region or Organization properties. Available with authoring Data Collector 5.6.0 or later. |
Connection Properties | Additional Snowflake connection properties to
use. To add properties, click Add and define the property name and value. Use the property names and values as expected by Snowflake. Available with Snowflake Enterprise stage library 1.11.0 or later. |
Snowpipe Connection
Available when using an authoring Data Collector version 4.0.0 or later.
- Data Collector 5.4.0 or later - Requires the Snowflake stage library,
streamsets-datacollector-sdc-snowflake-lib
. - Data Collector
4.0.0 to 5.3.x - Requires
version 1.7.x or later of the Snowflake Enterprise stage library,
streamsets-datacollector-snowflake-lib
.
For a description of the Snowpipe connection properties, see Snowpipe Connection Properties.
Engine | Stage |
---|---|
Data Collector 4.0.0 or later | Snowflake destination |
Snowpipe Connection Properties
Define a Snowpipe connection when configuring the Data Collector Snowflake destination to use the Snowpipe load method. Before creating a Snowpipe connection, make sure to complete the Snowpipe prerequisite tasks.
When creating a Snowpipe connection, configure the following properties on the Snowpipe tab:
Snowpipe Property | Description |
---|---|
Private Key PEM | Private key PEM. Generated in
Snowflake as part of the Snowpipe prerequisite
tasks. Tip: To secure sensitive
information, you can use credential stores or runtime resources. |
Private Key Password | Private key password. Generated in Snowflake as part of the Snowpipe prerequisite tasks. |
Public Key PEM | Public key PEM. Generated in Snowflake as part of the Snowpipe prerequisite tasks. |
Use Custom Snowpipe Endpoint | Enables using a custom Snowpipe endpoint. |
Use TLS | Enables the use of TLS to connect to the custom Snowpipe endpoint. |
Custom Snowpipe Host | Host name for the custom Snowpipe endpoint. |
Custom Snowpipe Port | Port number for the custom Snowpipe endpoint. |