3

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
4

2 に答える 2

5

まず第一に$args、自動変数です。設定できないので、のような行$args = fooは何もしません(厳密なモードがオンになっている場合でも、苦情はあればいいのですが)。

次に、1つの引数(文字列)のみをプログラムに渡します。スペースが含まれていますが、スペースは適切にエスケープされているか、括弧で囲まれているため、プログラムは1つの引数しか認識しません。

事前に変数に格納する場合は、単一の文字列ではなく、プログラムの引数に配列を使用する必要があります。そして、あなたはそれに別の名前を付ける必要があります$args

$arguments = "$($serverinfo['table'])",
             'out',"$($out_path)test.dat",
             '-N','-t,',
             '-U',"$($serverinfo['uid'])",
             '-P',"$($serverinfo['pwd'])",
             '-S',"$($serverinfo['server'])"

& $bcp_path $arguments

または、私が好むのは、実際には、ここで醜いもののほとんどを取り除く1行で簡単に書き出すことができます。

$out_path = 'c:\Temp\db'
& $bcp_path $serverinfo['table'] out $out_path\test.dat -N '-t,' -U $serverinfo['uid'] -P $serverinfo['pwd'] -S $serverinfo['server']
于 2010-03-19T22:10:51.000 に答える
1

スラッシュ、引用符、二重引用符、等号、コロン、ダッシュ、真のカクテルを含むクレイジーな江南スタイルの引数を受け入れる必要があるいくつかのコマンドラインアプリ。

私の経験では、PowerShellは時々対処できないことがあります。だから私は.cmdファイルに書き、次のようにcmd.exeからそれを実行します:

echo $("Running command: " + $commandLine);

$rnd = $(([string](Get-Random -Minimum 10000 -Maximum 99999999)) + ".cmd");
$commandFilePath = $(Join-Path -Path $env:TEMP -ChildPath $rnd);
echo $commandLine | Out-File -FilePath $commandFilePath -Encoding ascii;

& cmd.exe /c $commandFilePath

デフォルトのUnicodeはcmd.exeでうまく機能しない可能性があるため、ASCIIとして出力するようにしてください(最初の試行で吠え、奇妙な文字が表示されました)。

于 2012-12-20T16:59:21.800 に答える