html - 如何在 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 , 最有价值球员))
请帮助我使用缺少的代码来实现此功能。
谢谢你。
解决方案
以下是您可以修改 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'<', N'<'), N'>', N'>');
对于我的系统,然后输出:
希望这就是你所需要的。
推荐阅读
- ios - iPad Pro iPadOS 15.0.2 方向更改不起作用
- java - 如何在java中移动指定文件夹中的文件?
- multithreading - NachOS - 为什么运行 NachOS 时 Eclipse 无法识别我的新自动评分器类?
- apache-kafka - Kafka Streams API:避免在 KTable.mapValues 中添加额外的 stateStore
- reactjs - MUI v5 + styled() + ListItemButton: 属性 'to'/'component' 不存在
- python - 无法使用 Python 删除整个谷歌电子表格
- docker - 气流微风初始化失败
- stellar.js - 发行人锁定账户/信任线
- ios - 旋转设备时更改约束
- python - Pygame 冻结