PowerShell
kwerendy SQL PowerShell
Szukaj…
Wprowadzenie
Przeglądając ten dokument, możesz dowiedzieć się, jak korzystać z zapytań SQL w PowerShell
Parametry
Pozycja | Opis |
---|---|
$ ServerInstance | W tym miejscu musimy wspomnieć o instancji, w której baza danych jest obecna |
Baza danych $ | W tym miejscu musimy wspomnieć o bazie danych, w której znajduje się tabela |
$ Zapytanie | Tutaj mamy zapytanie, które chcemy wykonać w SQ |
$ Nazwa użytkownika i $ Hasło | Nazwa użytkownika i hasło, które mają dostęp do bazy danych |
Uwagi
Możesz użyć poniższej funkcji, jeśli nie możesz zaimportować modułu SQLPS
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();
}
}
SQLEprzykład
Do zapytania wszystkich danych z tabeli MachineName możemy użyć polecenia jak poniżej.
$ Query = "Wybierz * z MachineName"
$ Inst = „ServerInstance”
$ DbName = "nazwa bazy danych
$ UID = „ID użytkownika”
$ Hasło = „Hasło”
Invoke-Sqlcmd2 -Serverinstance $Inst -Database $DBName -query $Query -Username $UID -Password $Password
SQLQuery
Do zapytania wszystkich danych z tabeli MachineName możemy użyć polecenia jak poniżej.
$ Query = "Wybierz * z MachineName"
$ Inst = „ServerInstance”
$ DbName = "nazwa bazy danych
$ UID = „ID użytkownika”
$ Hasło = „Hasło”
Invoke-Sqlcmd2 -Serverinstance $Inst -Database $DBName -query $Query -Username $UID -Password $Password
Modified text is an extract of the original Stack Overflow Documentation
Licencjonowany na podstawie CC BY-SA 3.0
Nie związany z Stack Overflow