| This is documentation for Semarchy xDI 2024.3, which is no longer supported. For more information, see our Global Support and Maintenance Policy. | 
Snowflake Snowpipe Streaming

Description
The Snowpipe Streaming process action allows a target Snowflake table to ingest source data using the Snowpipe Streaming API.
In a process, the action requires an input bind link that contains source data. The action also exposes an output bind that contains any errors reported by Snowflake.
Also see Getting started with Snowpipe.
Prerequisites
- 
Valid Snowflake metadata must be dragged and dropped onto this action. 
- 
The metadata must have a valid Snowflake module defined. 
- 
The metadata must contain Snowpipe credentials. 
Parameters
| Parameter | Default value | Description | 
|---|---|---|
| Name | Snowflake Snowpipe Streaming | Display name given to the action. | 
| Target Database Name | (from metadata) | Name of the database in which the target table exists. | 
| Target Schema Name | (from metadata) | Name of the database schema in which the target table exists. | 
| Target Table Name | (from metadata) | Name of the target table. | 
| Channel Name | Semarchy xDI Channel | Name of the Snowpipe channel used to stream data to Snowflake. | 
| Offset Token Column Name | 
 | Name of the column in the source data that contains the value to use as an offset token. This column will not be inserted into the target. It should contain a value that uniquely identifies the source line, such as an auto-incremented numeric column or a timestamp, which allows processes to restart the streaming from that line. If you want to use the default value, make sure the offset token column in your data source uses  | 
| Offset Token Comparison | Enable | Enable: the tool compares the last committed offset token to the source data, and starts streaming lines after the one with the last offset token. This avoids inserting the same data twice, as long as offset tokens are unique. Disable: the tool tries to insert all data from the source set regardless of the offset token values. This may result in duplicates if pre-inserted data has not been removed from the source. | 
| On Error Behavior | Abort Execution | Continue Execution: execution continues after an error, and tries to insert all the lines from the source. Abort Execution: execution stops immediately after an error. The error is returned in the error message, and no lines from the job are commited to the target. | 
| Batch Size | 1000 | Number of lines sent to Snowflake as one batch. Adjust this value to stay under 16 MB per batch. | 
Statistics
| Name | Description | 
|---|---|
| 
 | Number of records reported as errors by Snowpipe Streaming. | 
| 
 | Number of records inserted successfully by Snowpipe Streaming. | 
Error messages
Compilation time
This action warns of the following errors when the process is built:
| Error type | Suggestions | 
|---|---|
| Mandatory fields have not been filled out. | 
 | 
| Action does not have Snowflake Metadata. | 
 | 
| Action does not have a bind link from a source action. | 
 | 
| There is no bind link to a target action, but On Error Behavior is set to Continue Execution. | 
 | 
Execution
This action returns the following errors when running the process:
| Error type | Suggestions | 
|---|---|
| Offset token type from source data is incompatible with last committed offset token returned by Snowflake. | 
 | 
| At least one error present in the inserted result set. | 
 | 
| On data insertion, last offset token returned by Snowflake does not match last offset token you sent. | 
 | 
| Chosen offset token column has an incorrect type | 
 |