如何正确传递参数?

时间:2015-02-03 15:41:48

标签: powershell

请参阅下面的我的功能:

Function Query {
    param (
        [string]$query
        [string]$server
        [string]$dbase
        [string]$user
        [string]$pass
    )

    if ($user) { 
        $connstr = "Server={0};Database={1};User ID={2};Password={3};Trusted_Connection=False;Connect Timeout=15" -f $server, $dbase, $user, $pass 
    } 
    else { 
        $connstr = "Server={0};Database={1};Integrated Security=True;Connect Timeout=15" -f $server, $dbase
    }
    $conn.ConnectionString = $connstr 


    switch ($query.Split()[0]) {
        "SELECT" {
            $cmd = New-Object System.Data.SqlClient.SqlCommand($query,$conn)
            $adapter = New-Object System.Data.SqlClient.SqlDataAdapter($cmd)
            $dataset = New-Object System.Data.DataSet
            $adapter.Fill($dataset) | Out-Null
            return $dataset
        }
        "UPDATE" {
            $cmd = New-Object System.Data.SqlClient.SqlCommand($query,$conn)
            return $cmd.ExecuteNonQuery()
        }
        "INSERT" {
            $cmd = New-Object System.Data.SqlClient.SqlCommand($query,$conn)
            return $cmd.ExecuteNonQuery()
        }
    }
}

Query -query "SELECT TOP 10 myField FROM myTable" -server "SQLEXPRESS" -dbase "TEST"

这不起作用,Powershell ISE在param部分给了我红色,但我不明白为什么。由于人们似乎构建Powershell函数的许多不同方式(我是初学者:))我有点困惑。

如何使此功能起作用?

1 个答案:

答案 0 :(得分:4)

在参数之间插入逗号,

Function SomeName {
  Param ($param1,$param2,$param3)
}

等。为了便于阅读,您可以在逗号后使用空格或换行符,这是大多数人所做的:

Function SomeName {
   param (
          $param1,
          $param2 
         )
}