简体   繁体   English

tmsl 脚本中的 powershell json 格式变量

[英]powershell json format variable in tmsl script

I use powershell and i want to put variable in json format into TMSL create role script.我使用 powershell 并且我想将 json 格式的变量放入 TMSL 创建角色脚本中。 I want to put this variable into TablePermission parameter我想将此变量放入 TablePermission 参数

json variable: json 变量:

$filter=
[

    {
          "name": "DimGeography",
          "filterExpression": "DimGeography[CountryRegionCode] = \"US\" "
        }
]

TMSL script: TMSL 脚本:

$Query='
    {  
    "create": {  
        "parentObject": {  
        "database": "AW Internet Sales"  
        },  
        "role": {
      "name": "test_filter",
      "modelPermission": "read",
      "tablePermissions": "'+$filter+'"
    }
        }
          
    }'

This is script which I want to parametrize这是我要参数化的脚本

{
  "createOrReplace": {
    "object": {
      "database": "AW Internet Sales",
      "role": "SalesManagerUS"
    },
    "role": {
      "name": "SalesManagerUS",
      "modelPermission": "read",
      "tablePermissions": [
        {
          "name": "DimGeography",
          "filterExpression": "DimGeography[CountryRegionCode] = \"US\" "
        }
      ]
    }
  }
}

How can I put $filter to $Query to receive working script like above?如何将 $filter 放入 $Query 以接收上述工作脚本?

You could try the below snippet:您可以尝试以下代码段:

    $filter=
'[

    {
          "name": "DimGeography",
          "filterExpression": "DimGeography[CountryRegionCode] = \"US\" "
        }
]'


function populate-tsml ($filter)
{


$Query='
    {  
    "create": {  
        "parentObject": {  
        "database": "AW Internet Sales"  
        },  
        "role": {
      "name": "test_filter",
      "modelPermission": "read",
      "tablePermissions": '+$filter+'
    }
        }
          
    }'

    return $Query

    }

  $Query =   populate-tsml -filter $filter

OUTPUT: OUTPUT:

在此处输入图像描述

Thank you, It wasn't necesseary to define a function.谢谢,不需要定义 function。 a little changes in quotation marks was enough: Script below works:引号中的一些变化就足够了:下面的脚本有效:

$filter=
'[

    {
          "name": "DimGeography",
          "filterExpression": "DimGeography[CountryRegionCode] = \"US\" "
        }
]'




$Query='
    {  
    "create": {  
        "parentObject": {  
        "database": "AW Internet Sales"  
        },  
        "role": {
      "name": "test_filter",
      "modelPermission": "read",
      "tablePermissions": '+$filter+'
    }
        }
          
    }'

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM