Сценарий сбрасывается на все задания агента SQL - PullRequest
0 голосов
/ 12 июля 2011

Я новичок в powershell и пытаюсь написать сценарий для всех заданий агента SQL. Я нашел фрагмент кода, который делает это благодаря ENRIQUE в SOLID QUALITY MENTORS.

Мой вопрос: как мне написать сценарий, если существует, отбрасывать для каждой работы? Options.ScriptJobs, кажется, не делает то, что я думаю, должно делать?

param ([строка] $ serverName, [строка] $ jobNameFile)

функция script-SQLJobs ([строка] $ сервер, [строка] $ jobNameFile) { [mirror.assembly] :: LoadWithPartialName ("Microsoft.SqlServer.Smo") | Out-Null

$srv = New-Object Microsoft.SqlServer.Management.Smo.Server("$server") 
$db  = New-Object Microsoft.SqlServer.Management.Smo.Database 
$scrp = New-Object Microsoft.SqlServer.Management.Smo.Scripter($srv) 
$scrp.Options.ScriptDrops = $TRUE 
$scrp.Options.WithDependencies = $TRUE 


$jobNameFile = "C:\SQLJOBS\Jobs.sql"
remove-item $jobNameFile

$jobs = $srv.JobServer.get_Jobs() 
$jobs=$jobs | Where-Object {$_.Name -notlike "sys*"}     

foreach($job in $jobs) 
{   
    $script=$job.Script() 
    $script >> $jobNameFile
    "GO" >> $jobNameFile 

} 

}

script-SQLJobs $ serverName $ jobNameFile

Большое спасибо.

Ответы [ 3 ]

0 голосов
/ 13 июля 2011

Вам необходимо предоставить объект параметров скрипта методу сценария:

$script=$job.Script($scrp)
0 голосов
/ 10 июля 2015

Вот скрипт Powershell, скопированный с http://www.johnsansom.com/script-sql-server-agent-jobs-using-powershell/, который был расширен для выполнения того, что вы хотите.

# Date:     16/02/14
# Author:   John Sansom
# Description:  PS script to generate all SQL Server Agent jobs on the given instance.
#       The script accepts an input file of server names.
# Version:  1.1
#
# Example Execution: .\Create_SQLAgentJobSripts.ps1 .\ServerNameList.txt

param([String]$ServerListPath)

#Load the input file into an Object array
$ServerNameList = get-content -path "Servers.txt"
#$ServerNameList = get-content -path $ServerListPath

#Load the SQL Server SMO Assemly
[System.Reflection.Assembly]::LoadWithPartialName("Microsoft.SqlServer.Smo") | Out-Null

#Create a new SqlConnection object
$objSQLConnection = New-Object System.Data.SqlClient.SqlConnection

#For each server in the array do the following..
foreach($ServerName in $ServerNameList)
{
    Try
    {
    $objSQLConnection.ConnectionString = "Server=$ServerName;Integrated Security=SSPI;"
        Write-Host "Trying to connect to SQL Server instance on $ServerName..." -NoNewline
        $objSQLConnection.Open() | Out-Null
        Write-Host "Success."
    $objSQLConnection.Close()
    }
    Catch
    {
    Write-Host -BackgroundColor Red -ForegroundColor White "Fail"
    $errText =  $Error[0].ToString()
        if ($errText.Contains("network-related"))
    {Write-Host "Connection Error. Check server name, port, firewall."}

    Write-Host $errText
    continue
    }

    #IF the output folder does not exist then create it
    $OutputFolder = ".\$ServerName"
    $DoesFolderExist = Test-Path $OutputFolder
    $null = if (!$DoesFolderExist){MKDIR "$OutputFolder"}

    #Create a new SMO instance for this $ServerName
    $srv = New-Object "Microsoft.SqlServer.Management.Smo.Server" $ServerName

    #Script out each SQL Server Agent Job for the server
    foreach($job in $srv.JobServer.Jobs)
    {
    Write-Host $job.Name

    $script = ""
    $script = $script + "-- Uninstall the job" + "`r`n"
    $script = $script + "DECLARE @jobId binary(16)" + "`r`n"
    $script = $script + "SELECT @jobId = job_id FROM msdb.dbo.sysjobs WHERE (name = N'$job')" + "`r`n"
    $script = $script + "IF (@jobId IS NOT NULL)" + "`r`n"
    $script = $script + "BEGIN" + "`r`n"
    $script = $script + "    EXEC msdb.dbo.sp_delete_job @job_id=@jobId, @delete_unused_schedule=1" + "`r`n"
    $script = $script + "END" + "`r`n"
    $script = $script + "GO`r`n"
    $script = $script + "`r`n"
    $script = $script + "-- Install the job" + "`r`n"
    $script = $script + $job.Script()
    $script = $script + "GO`r`n"

    $fileName = $job.Name -replace '\\', ''

    $script | out-file ".\$OutputFolder\$fileName.sql"
    }
}

ПРИМЕЧАНИЕ. На самом деле вы не хотите использовать команду DROP, созданную SMO, поскольку она зависит от идентификатора задания, что делает полученный скрипт не подлежащим повторному использованию.

0 голосов
/ 12 июля 2011

Вы можете исключить сценарии, которые не соответствуют словам «drop table».Например:

$srv.JobServer.Jobs | Where-Object {$_.Name -notlike "sys*"} | Foreach-Object{
        $script = $_.Script()

        if($script -notmatch 'DROP TABLE')
        {
            $script+ "`nGO`n"
        }

} | Out-File $jobNameFile

Другой (косметический) вариант - проверить все шаги шагов команды:

$srv.JobServer.Jobs | Where-Object {$_.Name -notlike "sys*"} | Foreach-Object{

    $cmd = $_.JobSteps | select -expand Command 

        if($cmd -match 'DROP TABLE')
        {
            $_.script()+ "`nGO`n"
        }       
} | Out-File $jobNameFile
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...