SSMS表格模型:通过一个xmla脚本创建多个分区

问题描述 投票:0回答:1

我需要使用通过SSMS运行的XMLA脚本来创建大量分区。有没有一种方法可以将多个分区的创建合并到一个脚本中。

在下面的示例中,我需要执行第一个脚本。完成后,我可以打开另一个脚本并执行它。非常耗时。

我如何重组代码以仅在一次执行中运行它?

脚本1:

  "createOrReplace": {
    "object": {
      "database": "MYDB",
      "table": "MYTABLE1",      "partition": "Partition"
    },
    "partition": {
      "name": "Process_OLD",      "dataView": "full",
      "source": {
        "type": "m",
        "expression": [
          "let",
          "    Source = #\"mySQL/MY_SCHEMA\",",          "    MY_SCHEMA= Source{[Schema=\"MY_SCHEMA\"]}[Data],",
          "    AllData = MY_SCHEMA{[Name=\"MYTABLE1\"]}[Data],",          "\t#\"Filtered Rows\" = Table.SelectRows(AllData, each  [DATE]  < 20170101)",
          "in",
          "    #\"Filtered Rows\""
        ]
      }
    }
  }
}

脚本2:

  "createOrReplace": {
    "object": {
      "database": "MYDB",
      "table": "MYTABLE2",      "partition": "Partition"
    },
    "partition": {
      "name": "Process_NEW",      "dataView": "full",
      "source": {
        "type": "m",
        "expression": [
          "let",
          "    Source = #\"mySQL/MY_SCHEMA\",",          "    MY_SCHEMA= Source{[Schema=\"MY_SCHEMA\"]}[Data],",
          "    AllData = MY_SCHEMA{[Name=\"MYTABLE1\"]}[Data],",          "\t#\"Filtered Rows\" = Table.SelectRows(AllData, each  [DATE]  >= 20170101)",
          "in",
          "    #\"Filtered Rows\""
        ]
      }
    }
  }
}
ssms ssas partitioning ssas-tabular
1个回答
0
投票

您可以在其周围放置sequence命令:

{
  "sequence": {
    "operations": [
      {
        "createOrReplace": {
          "object": {
            "database": "MYDB",
            "table": "MYTABLE1",
            "partition": "Partition"
          },
          "partition": {
            "name": "Process_OLD",
            "dataView": "full",
            "source": {
              "type": "m",
              "expression": [
                "let",
                "    Source = #\"mySQL/MY_SCHEMA\",",
                "    MY_SCHEMA= Source{[Schema=\"MY_SCHEMA\"]}[Data],",
                "    AllData = MY_SCHEMA{[Name=\"MYTABLE1\"]}[Data],",
                "\t#\"Filtered Rows\" = Table.SelectRows(AllData, each  [DATE]  < 20170101)",
                "in",
                "    #\"Filtered Rows\""
              ]
            }
          }
        }
      },
      {
        "createOrReplace": {
          "object": {
            "database": "MYDB",
            "table": "MYTABLE2",
            "partition": "Partition"
          },
          "partition": {
            "name": "Process_NEW",
            "dataView": "full",
            "source": {
              "type": "m",
              "expression": [
                "let",
                "    Source = #\"mySQL/MY_SCHEMA\",",
                "    MY_SCHEMA= Source{[Schema=\"MY_SCHEMA\"]}[Data],",
                "    AllData = MY_SCHEMA{[Name=\"MYTABLE1\"]}[Data],",
                "\t#\"Filtered Rows\" = Table.SelectRows(AllData, each  [DATE]  >= 20170101)",
                "in",
                "    #\"Filtered Rows\""
              ]
            }
          }
        }
      }
    ]
  }
}
© www.soinside.com 2019 - 2024. All rights reserved.