2

我正在尝试根据 Powershell 中 SQL Server 作业的 lastrunoutcome 属性更改写入主机输出的颜色...如...如果作业成功,lastrunoutcome 的输出为绿色的“成功”。 ...如果失败,则以红色显示“失败”。我有脚本工作以获得所需的工作状态......我只是不知道如何更改颜色。

这是我到目前为止所拥有的:

# Check for failed SQL jobs on multiple servers

[reflection.assembly]::LoadWithPartialName("Microsoft.SqlServer.Smo") | out-null

foreach ($svr in get-content "C:\serverlist2.txt")

{
   $a = get-date
   $BegDate = (Get-Date $a.AddDays(-1) -f d) + " 12:00:00 AM"
   $BegDateTrans = [system.datetime]$BegDate

   write-host $svr

   $srv=New-Object "Microsoft.SqlServer.Management.Smo.Server" "$svr"

   $srv.jobserver.jobs | where-object {$_.lastrundate -ge $BegDateTrans -and $_.Name -notlike "????????-????-????-????-????????????"} | format-table name,lastrunoutcome,lastrundate -autosize
foreach ($_.lastrunoutcome in $srv.jobserver.jobs)
{
   if ($_.lastrunoutcome = 0)
      {
      -forgroundcolor red
      }
   else
   {}
   }
}

这似乎是我得到的最接近的......但它给了我一个错误““LastRunOutcome”是一个只读属性。”

任何帮助将不胜感激!

谢谢!

情绪

4

2 回答 2

1

“Splat”参数允许您将参数名称-值对的哈希值传递给函数或 cmdlet。这个哈希可以增量构造......

$extraArgs = @{}
if ($thingsFailed) {
  $extraArgs["foregroundColor"] = "Red"
}

write-host "Message" @extraArgs

如果哈希为空,则不会添加任何内容,但如果$thingsFailed已设置,则输出将为红色。

于 2010-04-26T16:13:52.610 回答
1
if ($_.lastrunoutcome = 0)

看起来是个错误;它应该使用“-eq”运算符,而不是“=”。那是:

if ($_.lastrunoutcome -eq 0)
于 2010-04-26T16:53:07.433 回答