bcpを使用して、リモートSQLデータベースからいくつかのテーブルを抽出して保存する必要があります。テーブルごとにbcpを呼び出してデータを保存するPowerShellスクリプトを作成したいと思います。これまでのところ、bcpに必要な引数を作成するこのスクリプトがあります。ただし、argsをbcpに渡す方法がわかりません。スクリプトを実行するたびに、代わりにbcpヘルプが表示されます。これは私が得ていない本当に簡単なことであるに違いありません。
#commands bcp database.dbo.tablename out c:\temp\users.txt -N -t, -U uname -P pwd -S <servername>
$bcp_path = "C:\Program Files\Microsoft SQL Server\90\Tools\Binn\bcp.exe"
$serverinfo =@{}
$serverinfo.add('table','database.dbo.tablename')
$serverinfo.add('uid','uname')
$serverinfo.add('pwd','pwd')
$serverinfo.add('server','servername')
$out_path= "c:\Temp\db\"
$args = "$($serverinfo['table']) out $($out_path)test.dat -N -t, -U $($serverinfo['uid']) -P $($serverinfo['pwd']) -S $($serverinfo['server'])"
#this is the part I can't figure out
& $bcp_path $args