ソース データセット列を変換先のデータセット列にマップする

注意

この記事は、Data Factory のバージョン 1 に適用されます。

列マッピングは、ソース テーブルの "structure" に指定した列を、シンク テーブルの "structure" に指定した列にどのようにマップするかを指定するために使用できます。 columnMapping プロパティは、コピー アクティビティの typeProperties セクションにあります。

列マッピングは、次のシナリオをサポートしています。

  • ソース データセット構造のすべての列が、シンク データセット構造のすべての列にマップされる。
  • ソース データセット構造の列のサブセットが、シンク データセット構造のすべての列にマップされる。

次のエラー状態では例外が発生します。

  • シンク テーブルの "structure" の列数が、マッピングの指定数より多いか少ない。
  • 重複したマッピング。
  • SQL クエリの結果に、マッピングで指定されている列名がない。

注意

以下の例は Azure SQL と Azure BLOB 向けですが、四角形のデータセットをサポートする任意のデータ ストアにも適用できます。 例で適切なデータ ソース内のデータを示すには、データセットとリンクされているサービスの定義を調整します。

例 1 – Azure SQL から Azure BLOB への列マッピング

この例の入力テーブルには構造体が 1 つあり、Azure SQL Database 内の SQL テーブルをポイントしています。

{
    "name": "AzureSQLInput",
    "properties": {
        "structure": 
         [
           { "name": "userid"},
           { "name": "name"},
           { "name": "group"}
         ],
        "type": "AzureSqlTable",
        "linkedServiceName": "AzureSqlLinkedService",
        "typeProperties": {
            "tableName": "MyTable"
        },
        "availability": {
            "frequency": "Hour",
            "interval": 1
        },
        "external": true,
        "policy": {
            "externalData": {
                "retryInterval": "00:01:00",
                "retryTimeout": "00:10:00",
                "maximumRetry": 3
            }
        }
    }
}

この例の出力テーブルには構造体が 1 つあり、Azure BLOB ストレージ内の BLOB をポイントしています。

{
    "name": "AzureBlobOutput",
    "properties":
    {
         "structure": 
          [
                { "name": "myuserid"},
                { "name": "myname" },
                { "name": "mygroup"}
          ],
        "type": "AzureBlob",
        "linkedServiceName": "StorageLinkedService",
        "typeProperties": {
            "folderPath": "mycontainer/myfolder",
            "fileName":"myfile.csv",
            "format":
            {
                "type": "TextFormat",
                "columnDelimiter": ","
            }
        },
        "availability":
        {
            "frequency": "Hour",
            "interval": 1
        }
    }
}

次の JSON は、パイプラインのコピー アクティビティを定義します。 ソースの列は、Translator プロパティを使用して、シンク (columnMappings) の列にマップされます。

{
    "name": "CopyActivity",
    "description": "description", 
    "type": "Copy",
    "inputs":  [ { "name": "AzureSQLInput"  } ],
    "outputs":  [ { "name": "AzureBlobOutput" } ],
    "typeProperties":    {
        "source":
        {
            "type": "SqlSource"
        },
        "sink":
        {
            "type": "BlobSink"
        },
        "translator": 
        {
            "type": "TabularTranslator",
            "ColumnMappings": "UserId: MyUserId, Group: MyGroup, Name: MyName"
        }
    },
   "scheduler": {
          "frequency": "Hour",
          "interval": 1
        }
}

列マッピングのフロー:

列マッピングのフロー

例 2 – SQL クエリを使用した Azure SQL から Azure BLOB への列マッピング

このサンプルでは、"structure" セクションでテーブル名と列名を単純に指定する代わりに、SQL クエリを Azure SQL からデータを抽出するために使用しています。

{
    "name": "CopyActivity",
    "description": "description", 
    "type": "CopyActivity",
    "inputs":  [ { "name": " AzureSQLInput"  } ],
    "outputs":  [ { "name": " AzureBlobOutput" } ],
    "typeProperties":
    {
        "source":
        {
            "type": "SqlSource",
            "SqlReaderQuery": "$$Text.Format('SELECT * FROM MyTable WHERE StartDateTime = \\'{0:yyyyMMdd-HH}\\'', WindowStart)"
        },
        "sink":
        {
            "type": "BlobSink"
        },
        "Translator": 
        {
            "type": "TabularTranslator",
            "ColumnMappings": "UserId: MyUserId, Group: MyGroup,Name: MyName"
        }
    },
    "scheduler": {
          "frequency": "Hour",
          "interval": 1
        }
}

この場合、クエリの結果は、ソースの "structure" で指定された列に最初にマップされます。 次に、ソース "structure" からの列が、columnMappings で指定した規則によって、シンク "structure" 内の列にマップされます。 たとえばこのクエリは、ソースの "structure" で指定された列よりも 2 つ多い、5 つの列を返しています。

列マッピングのフロー

列マッピングのフロー - 2

次のステップ

コピー アクティビティの使用に関するチュートリアルは、次の記事をご覧ください。