首页 > 解决方案 > 如何在 SQL SP 中有条件地格式化 HTML TABLE

问题描述

我创建了一个 SP 来监视 SQL Server 代理作业并以 HTML 格式生成相同的电子邮件。但是,我想根据单元格值(文本-成功/失败)有条件地将运行状态列格式化为红色/绿色。请在https://social.msdn.microsoft.com/Forums/sqlserver/en-US/2663e23b-0b55-4816-beb8-fdf8a020396d/formating-msdbdbospsenddbmail?forum=transactsql找到代码 (Hilary Cotter 标记的答案(MCC , 最有价值球员))

请帮助我使用缺少的代码来实现此功能。

谢谢你。

标签: htmlsql-serverssissql-server-agent

解决方案


以下是您可以修改 HTML 的创建以使其正常工作的方法:

DECLARE @tableHTML nvarchar(max);

SET @tableHTML = 
N'<style type="text/css">h2, body {font-family: Arial, verdana;}
table{font-size:11px; border-collapse:collapse;}
td{background-color:#F1F1F1; border:1px solid black; padding:3px;}
th{background-color:#99CCFF;}</style>' 
+ N'<h2>Recent Job Status</h2>'
+ N'<table border="1">' + N'<tr>
<th>Job Name</th>
<th>Last Run Date</th>
<th>Last Run Time</th>
<th>Last Run Status</th>'
+ CAST(( SELECT td = j.[name], 
                '', 
                td = MAX(jh.run_date), 
                '', 
                td = MAX(run_time),
                '', 
                td = CASE run_status 
                         WHEN 0
                         THEN N'<font color="red">Failure</font>'
                         WHEN 1
                         THEN N'<font color="green">Success</font>'
                         WHEN 2
                         THEN N'<font color="yellow">Retry</font>'
                         WHEN 3
                         THEN N'<font color="blue">Cancellation</font>'
                         WHEN 4
                         THEN N'<font color="black">In Progress</font>'
                         ELSE N'<font color="black">Unknown</font'
                    END
            FROM dbo.sysjobhistory AS jh
            INNER JOIN dbo.sysjobs AS j
            ON j.job_id = jh.job_id
            WHERE CONVERT(datetime, 
                          SUBSTRING(CONVERT(varchar(12), jh.run_date),
                                    0, 5) + N'-'
                  + SUBSTRING(CONVERT(varchar(12), jh.run_date), 5, 2) + '-'
                  + SUBSTRING(CONVERT(varchar(12), jh.run_date), 7, 2)) > DATEADD(day, -1, GETDATE())
            AND j.category_id <> 14
            GROUP BY j.[name], jh.run_status  
            FOR XML PATH('tr'), TYPE) AS NVARCHAR(MAX)) + N'</table>';
SET @tableHTML = REPLACE(REPLACE(@tableHTML, N'&lt;', N'<'), N'&gt;', N'>');

对于我的系统,然后输出:

带有彩色状态的示例输出

希望这就是你所需要的。


推荐阅读