PowerShell
Powershell SQL-Abfragen
Suche…
Einführung
In diesem Dokument erfahren Sie, wie Sie SQL-Abfragen mit Powershell verwenden
Parameter
Artikel | Beschreibung |
---|---|
$ ServerInstance | Hier muss die Instanz erwähnt werden, in der die Datenbank vorhanden ist |
$ Datenbank | Hier müssen wir die Datenbank erwähnen, in der die Tabelle vorhanden ist |
$ Query | Hier haben wir die Abfrage, die Sie in SQ ausführen möchten |
$ Benutzername & $ Passwort | Benutzername und Passwort, die Zugriff auf die Datenbank haben |
Bemerkungen
Sie können die unten stehende Funktion verwenden, wenn Sie kein SQLPS-Modul importieren können
function Import-Xls
{
[CmdletBinding(SupportsShouldProcess=$true)]
Param(
[parameter(
mandatory=$true,
position=1,
ValueFromPipeline=$true,
ValueFromPipelineByPropertyName=$true)]
[String[]]
$Path,
[parameter(mandatory=$false)]
$Worksheet = 1,
[parameter(mandatory=$false)]
[switch]
$Force
)
Begin
{
function GetTempFileName($extension)
{
$temp = [io.path]::GetTempFileName();
$params = @{
Path = $temp;
Destination = $temp + $extension;
Confirm = $false;
Verbose = $VerbosePreference;
}
Move-Item @params;
$temp += $extension;
return $temp;
}
# since an extension like .xls can have multiple formats, this
# will need to be changed
#
$xlFileFormats = @{
# single worksheet formats
'.csv' = 6; # 6, 22, 23, 24
'.dbf' = 11; # 7, 8, 11
'.dif' = 9; #
'.prn' = 36; #
'.slk' = 2; # 2, 10
'.wk1' = 31; # 5, 30, 31
'.wk3' = 32; # 15, 32
'.wk4' = 38; #
'.wks' = 4; #
'.xlw' = 35; #
# multiple worksheet formats
'.xls' = -4143; # -4143, 1, 16, 18, 29, 33, 39, 43
'.xlsb' = 50; #
'.xlsm' = 52; #
'.xlsx' = 51; #
'.xml' = 46; #
'.ods' = 60; #
}
$xl = New-Object -ComObject Excel.Application;
$xl.DisplayAlerts = $false;
$xl.Visible = $false;
}
Process
{
$Path | ForEach-Object {
if ($Force -or $psCmdlet.ShouldProcess($_)) {
$fileExist = Test-Path $_
if (-not $fileExist) {
Write-Error "Error: $_ does not exist" -Category ResourceUnavailable;
} else {
# create temporary .csv file from excel file and import .csv
#
$_ = (Resolve-Path $_).toString();
$wb = $xl.Workbooks.Add($_);
if ($?) {
$csvTemp = GetTempFileName(".csv");
$ws = $wb.Worksheets.Item($Worksheet);
$ws.SaveAs($csvTemp, $xlFileFormats[".csv"]);
$wb.Close($false);
Remove-Variable -Name ('ws', 'wb') -Confirm:$false;
Import-Csv $csvTemp;
Remove-Item $csvTemp -Confirm:$false -Verbose:$VerbosePreference;
}
}
}
}
}
End
{
$xl.Quit();
Remove-Variable -name xl -Confirm:$false;
[gc]::Collect();
}
}
SQLEexample
Um alle Daten aus der Tabelle MachineName abzufragen , können Sie den folgenden Befehl verwenden.
$ Query = "Select * from MachineName"
$ Inst = "ServerInstance"
$ DbName = "DatabaseName
$ UID = "Benutzer-ID"
$ Password = "Passwort"
Invoke-Sqlcmd2 -Serverinstance $Inst -Database $DBName -query $Query -Username $UID -Password $Password
SQLQuery
Um alle Daten aus der Tabelle MachineName abzufragen , können Sie den folgenden Befehl verwenden.
$ Query = "Select * from MachineName"
$ Inst = "ServerInstance"
$ DbName = "DatabaseName
$ UID = "Benutzer-ID"
$ Password = "Passwort"
Invoke-Sqlcmd2 -Serverinstance $Inst -Database $DBName -query $Query -Username $UID -Password $Password
Modified text is an extract of the original Stack Overflow Documentation
Lizenziert unter CC BY-SA 3.0
Nicht angeschlossen an Stack Overflow