Azure Synapse Analytics Task

Applies to: SQL Server SSIS Integration Runtime in Azure Data Factory

The Azure Synapse Analytics Task enables an SSIS package to copy tabular data to Azure Synapse Analytics dedicated SQL pool from file system or Azure Blob Storage. The task leverages PolyBase to improve performance, as described in the article Azure Synapse Analytics Loading Patterns and Strategies. The currently supported source data file format is delimited text in UTF8 encoding. When copying from file system, data will first be uploaded to Azure Blob Storage for staging, and then to dedicated SQL pool. Therefore, an Azure Blob Storage account is needed.

Note

Azure Storage connection manager with Data Lake Gen2 service type is not supported.

To use Azure Data Lake Gen2 for staging or source, you can connect via Azure Storage connection manager with the Azure Blob Storage type.

The Azure Synapse Analytics Task is a component of the SQL Server Integration Services (SSIS) Feature Pack for Azure.

To add an Azure Synapse Analytics Task, drag-drop it from SSIS Toolbox to the designer canvas, and double-click or right-click and click Edit to see the task editor dialog box.

On the General page, configure the following properties.

The SourceType specifies the type of source data store. Select one of the following types:

  • FileSystem: Source data resides in local file system.
  • BlobStorage: Source data resides in Azure Blob Storage.

Following are the properties for each source type.

FileSystem

Field Description
LocalDirectory Specifies the local directory that contains the data files to be uploaded.
Recursively Specifies whether to recursively search sub-directories.
FileName Specifies a name filter to select files with certain name pattern. E.g. MySheet*.xsl* will include files such as MySheet001.xsl and MySheetABC.xslx.
RowDelimiter Specifies the character(s) that marks the end of each row.
ColumnDelimiter Specifies one or more characters that mark the end of each column. E.g. | (pipe), \t (tab), ' (single quote), " (double quote), and 0x5c (backslash).
IsFirstRowHeader Specifies whether the first row in each data file contains column names instead of actual data.
AzureStorageConnection Specifies an Azure Storage connection manager.
BlobContainer Specifies the name of blob container to which local data will be uploaded and relayed to Azure Synapse Analytics dedicated SQL pool via PolyBase. A new container will be created if it does not exist.
BlobDirectory Specifies the blob directory (virtual hierarchical structure) to which local data will be uploaded and relayed to Azure Synapse Analytics dedicated SQL pool via PolyBase.
RetainFiles Specifies whether to retain the files uploaded to Azure Storage.
CompressionType Specifies the compression format to use upon uploading files to Azure Storage. Local source is not affected.
CompressionLevel Specifies the compression level to use for the compression format.
SqlPoolConnection Specifies an ADO.NET connection manager for Azure Synapse Analytics dedicated SQL pool.
TableName Specifies name of the destination table. Either choose an existing table name, or create a new one by choosing <New Table ...>.
TableDistribution Specifies the distribution method for new table. Applies if a new table name is specified for TableName.
HashColumnName Specifies the column used for hash table distribution. Applies if HASH is specified for TableDistribution.

BlobStorage

Field Description
AzureStorageConnection Specifies an Azure Storage connection manager.
BlobContainer Specifies the name of blob container where source data resides.
BlobDirectory Specifies the blob directory (virtual hierarchical structure) where source data resides.
RowDelimiter Specifies the character(s) that marks the end of each row.
ColumnDelimiter Specifies one or more characters that mark the end of each column. E.g. | (pipe), \t (tab), ' (single quote), " (double quote), and 0x5c (backslash).
CompressionType Specifies the compression format used for source data.
SqlPoolConnection Specifies an ADO.NET connection manager for Azure Synapse Analytics dedicated SQL pool.
TableName Specifies name of the destination table. Either choose an existing table name, or create a new one by choosing <New Table ...>.
TableDistribution Specifies the distribution method for new table. Applies if a new table name is specified for TableName.
HashColumnName Specifies the column used for hash table distribution. Applies if HASH is specified for TableDistribution.

You will see a different Mappings page depending on whether you are copying to a new table or to an existing one. In the former case, configure which source columns are to be mapped and their corresponding names in the to-be-created destination table. In the latter case, configure the mapping relationships between source and destination columns.

On the Columns page, configure the data type properties for each source column.

The T-SQL page shows the T-SQL used to load data from Azure Blob Storage to dedicated SQL pool. The T-SQL is automatically generated from configurations on the other pages, and will be executed as part of the task execution. You may choose to manually edit the generated T-SQL to meet your particular needs by clicking the Edit button. You can revert to the automatically generated one later on by clicking the Reset button.