【发布时间】:2016-11-22 12:35:09
【问题描述】:
我有一个使用 DataAdapter 从 MySQL 数据库读取的脚本。表 idInstance、IPAddress 和 auto id 列中有三列。我只希望 IdInstance 和 IPAddress 显示在报告中,但是当我运行脚本并输出到表中时,我得到 7 列,额外的 5 列是 RowError、RowState、Table、ItemArray 和 HasErrors。如何只显示我想要的 2 列 IdInstance 和 IpAddress 列。请参阅额外列的图像。此外,控制台的输出是正确的,它只显示 idinstance 和 ipaddress。所以它必须是用于构建 HTML 表的代码中的某些内容?
function Execute-MySQLQuery([string]$query) {
$command = New-Object MySql.Data.MySqlClient.MySqlCommand($query, $conn)
$dataAdapter = New-Object MySql.Data.MySqlClient.MySqlDataAdapter($command)
$dataSet = New-Object System.Data.DataSet
$dataAdapter.Fill($dataSet, "data")
$command.Dispose()
return $dataSet.Tables["data"]
}
# So, to produce a table of results from a query...
$Header = @"
<style>
TABLE {border-width: 1px;border-style: solid;border-color: black;border-collapse: collapse;}
TR:Nth-Child(Even) {Background-Color: #dddddd;}
TH {border-width: 1px;padding: 3px;border-style: solid;border-color: black;background-color: #6495ED;}
TD {border-width: 1px;padding: 3px;border-style: solid;border-color: black;}
</style>
<title>
Patch Report
</title>
"@
$Pre = "<h1>Patch Report </h1>"
$Pre += "<h2>These systmes are Not Running Patch Script</h2>"
$Post = "Run on "
$Post += Get-Date
$query = " SELECT prodinstances.Idinstance, prodinstances.IPAddress
FROM prodinstances
WHERE prodinstances.Idinstance
NOT IN (select prodwinupdates.ServersId FROM prodwinupdates) order by IPAddress ASC"
$result = Execute-MySQLQuery $query
$strfound = ("Found " + $result.rows.count + " Systems that are not currnetly running Patch Audit Script.")
$result | Format-Table
$emailSmtpServer = "mysmtpserver"
$emailFrom = "noreply@email.com"
$emailTo = "emailto@email.com"
$emailSubject = $strfound
$emailBody = $result | ConvertTo-HTML -Head $Header -PreContent $Pre -PostContent $Post | Out-String
Send-MailMessage -To $emailTo -From $emailFrom -Subject $emailSubject -Body $emailBody -BodyAsHtml -SmtpServer $emailSmtpServe
【问题讨论】:
标签: html mysql powershell html-table