큰 CSV 파일이 있으며 각 줄에 대해 저장 프로 시저를 실행하고 싶습니다.
PowerShell에서 저장 프로 시저를 실행하는 가장 좋은 방법은 무엇입니까?
이 답변은 http://www.databasejournal.com/features/mssql/article.php/3683181
이 예제는 모든 임시 쿼리에 사용할 수 있습니다. 아래와 같이 저장 프로 시저“sp_helpdb”를 실행하겠습니다.
$SqlConnection = New-Object System.Data.SqlClient.SqlConnection
$SqlConnection.ConnectionString = "Server=HOME\SQLEXPRESS;Database=master;Integrated Security=True"
$SqlCmd = New-Object System.Data.SqlClient.SqlCommand
$SqlCmd.CommandText = "sp_helpdb"
$SqlCmd.Connection = $SqlConnection
$SqlAdapter = New-Object System.Data.SqlClient.SqlDataAdapter
$SqlAdapter.SelectCommand = $SqlCmd
$DataSet = New-Object System.Data.DataSet
$SqlAdapter.Fill($DataSet)
$SqlConnection.Close()
$DataSet.Tables[0]
다음은 내가 사용하는 기능입니다 (약간 수정 됨). 입력 및 출력 매개 변수를 허용합니다. uniqueidentifier 및 varchar 유형 만 구현했지만 다른 유형은 쉽게 추가 할 수 있습니다. 매개 변수가있는 저장 프로 시저 (또는 매개 변수가있는 sql ...이 코드는 쉽게 적용 할 수 있음)를 사용하면 인생을 훨씬 쉽게 만들 수 있습니다.
함수를 호출하려면 SQL 서버에 연결해야합니다 (예 : $ conn).
$ res = exec-storedprocedure -storedProcName 'stp_myProc'-parameters @ {Param1 = "Hello"; Param2 = 50} -outparams @ {ID = "고유 식별자"} $ conn
반환 된 객체에서 proc 출력 검색
$ res.data #selects에 의해 반환 된 데이터 테이블을 포함하는 데이터 셋
$ res.outputparams.ID # 출력 매개 변수 ID (고유 식별자)
함수:
function exec-storedprocedure($storedProcName,
[hashtable] [email protected]{},
[hashtable] [email protected]{},
$conn,[switch]$help){
function put-outputparameters($cmd, $outparams){
foreach($outp in $outparams.Keys){
$cmd.Parameters.Add("@$outp", (get-paramtype $outparams[$outp])).Direction=[System.Data.ParameterDirection]::Output
}
}
function get-outputparameters($cmd,$outparams){
foreach($p in $cmd.Parameters){
if ($p.Direction -eq [System.Data.ParameterDirection]::Output){
$outparams[$p.ParameterName.Replace("@","")]=$p.Value
}
}
}
function get-paramtype($typename,[switch]$help){
switch ($typename){
'uniqueidentifier' {[System.Data.SqlDbType]::UniqueIdentifier}
'int' {[System.Data.SqlDbType]::Int}
'xml' {[System.Data.SqlDbType]::Xml}
'nvarchar' {[System.Data.SqlDbType]::NVarchar}
default {[System.Data.SqlDbType]::Varchar}
}
}
if ($help){
$msg = @"
Execute a sql statement. Parameters are allowed.
Input parameters should be a dictionary of parameter names and values.
Output parameters should be a dictionary of parameter names and types.
Return value will usually be a list of datarows.
Usage: exec-query sql [inputparameters] [outputparameters] [conn] [-help]
"@
Write-Host $msg
return
}
$close=($conn.State -eq [System.Data.ConnectionState]'Closed')
if ($close) {
$conn.Open()
}
$cmd=new-object system.Data.SqlClient.SqlCommand($sql,$conn)
$cmd.CommandType=[System.Data.CommandType]'StoredProcedure'
$cmd.CommandText=$storedProcName
foreach($p in $parameters.Keys){
$cmd.Parameters.AddWithValue("@$p",[string]$parameters[$p]).Direction=
[System.Data.ParameterDirection]::Input
}
put-outputparameters $cmd $outparams
$ds=New-Object system.Data.DataSet
$da=New-Object system.Data.SqlClient.SqlDataAdapter($cmd)
[Void]$da.fill($ds)
if ($close) {
$conn.Close()
}
get-outputparameters $cmd $outparams
return @{data=$ds;outputparams=$outparams}
}
다음은 SQL 명령을 실행하는 데 사용되는 기능입니다. $ sqlCommand.CommandText를 sproc의 이름으로 변경하고 $ SqlCommand.CommandType을 CommandType.StoredProcedure로 변경하면됩니다.
function execute-Sql{
param($server, $db, $sql )
$sqlConnection = new-object System.Data.SqlClient.SqlConnection
$sqlConnection.ConnectionString = 'server=' + $server + ';integrated security=TRUE;database=' + $db
$sqlConnection.Open()
$sqlCommand = new-object System.Data.SqlClient.SqlCommand
$sqlCommand.CommandTimeout = 120
$sqlCommand.Connection = $sqlConnection
$sqlCommand.CommandText= $sql
$text = $sql.Substring(0, 50)
Write-Progress -Activity "Executing SQL" -Status "Executing SQL => $text..."
Write-Host "Executing SQL => $text..."
$result = $sqlCommand.ExecuteNonQuery()
$sqlConnection.Close()
}
2005 데이터베이스 인 경우 osql 대신 sqlcmd를 사용하십시오.
스토어드 프로 시저에 대한 호출과 함께 각 라인에 대해 작성된 텍스트 파일을 매개 변수로 전달하는 osql.exe (SQL Server의 명령 행 도구)를 호출하십시오.
SQL Server는 PowerShell과 완벽하게 통합 된 SMO라는 이름으로 사용할 수있는 일부 어셈블리를 제공합니다. 여기에 기사가 있습니다.
http://www.databasejournal.com/features/mssql/article.php/3696731
조사 할 가치가있는 저장 프로 시저를 실행하는 API 메서드가 있습니다. 시작 예제는 다음과 같습니다.
http://www.eggheadcafe.com/software/aspnet/29974894/smo-running-a-stored-pro.aspx
http://blogs.technet.com/b/heyscriptingguy/archive/2010/11/01/use-powershell-to-collect-에서 invoke-sqlcmd2.ps1
및 write-datatable.ps1
를 포함합니다. server-data-and-write-to-sql.aspx . SQL 명령을 실행하기위한 호출은 다음과 같은 형식을 취합니다.Invoke-sqlcmd2 -ServerInstance "<sql-server>" -Database <DB> -Query "truncate table <table>"
DataTable 변수의 내용을 SQL 테이블에 쓰는 예는 다음과 같습니다.$logs = (get-item SQLSERVER:\sql\<server_path>).ReadErrorLog() Write-DataTable -ServerInstance "<sql-server>" -Database "<DB>" -TableName "<table>" -Data $logs
결과 스크립트가 깨끗하고 읽을 수 있으므로 SQL Server 데이터베이스 관련 PowerShell 스크립트를 수행 할 때 유용합니다.