回答
這個答案是從http://www.databasejournal.com/features/mssql/article.php/3683181
同一例子拉到2005數據庫,可用於任何即席查詢。讓我們執行存儲過程「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]
考慮調用osql.exe(SQL Server的命令行工具),以調用存儲過程的方式傳遞每行所寫的文本文件作爲參數。
SQL Server提供了一些可以與名稱SMO一起使用的程序集,這些程序集可以與PowerShell無縫集成。這裏有一篇文章。
http://www.databasejournal.com/features/mssql/article.php/3696731
有API的方法來執行,我認爲是值得正在調查中的存儲過程。這裏啓動例如:
http://www.eggheadcafe.com/software/aspnet/29974894/smo-running-a-stored-pro.aspx
使用SQLCMD代替OSQL如果它是一個
如果您在運行該腳本的計算機上安裝了工具,這將會起作用(並且是一個非常簡單的解決方案)。否則,使用.NET的System.Data.SqlClient似乎是必要的。 – 2009-02-23 22:44:30
這是我用來執行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()
}
這是我使用的一個函數(稍微編輯)。它允許輸入和輸出參數。我只有uniqueidentifier和varchar類型實現,但任何其他類型都很容易添加。如果你使用參數化的存儲過程(或者只是參數化的sql ...這個代碼很容易適應這個),這會讓你的生活變得更容易。
要調用的函數,你需要在SQL服務器的連接(比如$康恩),
$水庫= EXEC-StoredProcedure的-storedProcName 'stp_myProc' α參數@ {參數1 = 「你好」;參數2 = 50} -outparams @ {ID = 「唯一標識符」} $康恩
從返回的對象檢索PROC輸出
$包含由選擇返回的數據表res.data #dataset
$ res.outputparams.ID #output參數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}
}
在NVARCHAR輸出變量上,你必須指定Size屬性,所以上面的代碼會導致錯誤。 – yonsk 2014-04-17 09:38:48
我包括invoke-sqlcmd2.ps1
和從http://blogs.technet.com/b/heyscriptingguy/archive/2010/11/01/use-powershell-to-collect-server-data-and-write-to-sql.aspxwrite-datatable.ps1
。調用運行SQL命令的形式是:Invoke-sqlcmd2 -ServerInstance "<sql-server>" -Database <DB> -Query "truncate table <table>"
寫數據表變量的內容到SQL表的示例如下:$logs = (get-item SQLSERVER:\sql\<server_path>).ReadErrorLog() Write-DataTable -ServerInstance "<sql-server>" -Database "<DB>" -TableName "<table>" -Data $logs
我發現這些有用做當SQL Server數據庫相關的PowerShell腳本作爲所產生的腳本是乾淨的並可讀。
- 1. 如何從SQL Server存儲過程
- 2. 從SQL Server存儲過程
- 3. 如何從SQL Server 2000調用MySQL存儲過程?
- 4. 如何從SQL Server中調用另一個存儲過程
- 5. 如何避免從SQL Server中的UDF調用存儲過程
- 6. 調用存儲過程在SQL Server
- 7. 從另一個存儲過程的SQL Server調用存儲過程
- 8. 從日期時間從vb6調用Sql Server 2008存儲過程
- 9. 如何調用存儲過程使用Hibernate con Sql Server 2000?
- 10. 如何使用PHP和SQL Server 2008調用存儲過程
- 11. 調試SQL Server 2005存儲過程
- 12. 從SQL Server存儲過程執行Oracle存儲過程
- 13. 使用dbfcmd和dbrpcsend從C++調用SQL Server存儲過程
- 14. 如何寫SQL Server存儲過程
- 15. 如何保護SQL Server存儲過程
- 16. 如何選擇SQL Server存儲過程
- 17. 如何從另一個存儲過程調用存儲過程?
- 18. 使用powershell調用存儲過程
- 19. 使用嵌套的存儲過程結果調用存儲過程Sql Server 2008
- 20. SQL存儲過程從.NET調用
- 21. SQL Server 2005:從WHERE子句中調用存儲過程
- 22. 調用SQL Server 2008的存儲過程從PHP
- 23. 從PHP傳入參數調用SQL Server 2008存儲過程
- 24. 從Visual Foxpro調用SQL Server存儲過程9
- 25. 從DLL執行SQL Server存儲過程
- 26. 從SQL Server運行PostgreSQL存儲過程
- 27. SQL Server存儲過程sp_executesql
- 28. SQL Server的存儲過程
- 29. sql server 2000存儲過程
- 30. SQL Server存儲過程
注意:如果您正在調用具有參數的存儲過程,則還應該設置命令類型:$ sqlCmd.CommandType = [System.Data.CommandType] :: StoredProcedure。 – Hutch 2015-04-15 17:13:38