sp_send_dbmail中套用HTML样式

使用sp_send_dbmail发送HTML格式的邮件时,将某个列<td>套用Style
 SET @tableHTML = N'<HTML><HEAD> 
                         <style type="text/css">
                         th
                         {  height:30px;
                            width: 80px;
                            text-align:center;   
                         }
                         td
                         {  height:30px;
                            width: 80px;
                            text-align:left;
                            colspan="1";             
                         }
                         .amt{
			    text-align:right;
                         }     
                        </style>
                      </HEAD>
                    <BODY>' + @tableHead
                    + N'<table border="1" bordercolor="black" cellpadding="0" cellspacing="0" ><tr>'
                    + N'<th>公司别</th><th>报销日期</th><th class="no">表单单号</th><th>报销人</th><th>姓名</th><th>所在部门</th><th class="dept">部门名称</th>'
                    + N'<th>扣减部门</th><th  class="dept">部门名称</th><th class="content">摘要</th><th>科目</th><th>科目名称</th>'
                    + N'<th class="currency">币别</th><th>报销金额</th></tr>'
                    + CAST(( SELECT CASE WHEN amts>1000 THEN 'red' ELSE 'green' END AS '@class',
                                    td = company,
                                    '' ,
                                    td = paydate,
                                    '' ,
                                    td = payid,
                                    '' ,
                                    td = employeeid,
                                    '' ,
                                    td = employee,
                                    '' ,
                                    td = deptid,
                                    '' ,
                                    td = dept,
                                    '' ,
                                    td = factdeptid ,
                                    '' ,
                                    td = factdept,
                                    '' ,
                                    td = content,
                                    '' ,
                                    td = account,
                                    '' ,
                                    td = accdesc,
                                    '' ,
                                    td = currency,
                                    '' ,
                                    'amt' AS 'td/@class' ,
                                    CONVERT(DECIMAL(12, 2), amts) AS 'td'
                             FROM   sometable
                           FOR
                             XML PATH('tr') ,
                                 TYPE
                           ) AS NVARCHAR(MAX)) + N'</table><br><br>'
                    + @tableFoot + '</body></HTML>'


CASE WHEN amts>1000 THEN 'red' ELSE 'green' END AS '@class'
上面的SQL会更具条件被解释为

<tr class='red'>或者<tr class='green'>

实现行样式

'amt' AS 'td/@class' ,
 CONVERT(DECIMAL(12, 2), amts) AS 'td'
上面的SQL会被解释为

<td class='amt'>[amts]</td>,实现针对某个列套用样式


EXEC msdb.dbo.sp_send_dbmail @profile_name = 'DatabaseMailProfile',
@recipients = @mailadd ,@copy_recipients = @copymailadd,
@subject = N'Mail Subject', @body = @tableHTML,
@body_format = 'HTML'		




  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要在 SQL Server 2008 R2 查询数据并发送电子邮件,您可以使用 SQL Server 的内置功能和存储过程。以下是一些步骤: 1. 配置 SQL Server 的电子邮件设置。在 SQL Server Management Studio ,右键单击“管理”文件夹,然后选择“Database Mail”。按照向导的指示配置电子邮件设置。 2. 创建一个存储过程来查询数据。例如,以下是一个查询订单的存储过程: CREATE PROCEDURE GetOrders AS BEGIN SELECT * FROM Orders END 3. 在存储过程添加发送电子邮件的代码。以下是一个示例: USE msdb GO EXEC sp_send_dbmail @profile_name='Database Mail Profile', @recipients='example@email.com', @subject='Orders Report', @body='Please see the attached report.', @query='EXEC GetOrders', @attach_query_result_as_file=1, @query_attachment_filename='Orders.csv', @query_result_separator=',', @query_result_no_padding=1 在此示例,使用 sp_send_dbmail 存储过程发送电子邮件。参数包括电子邮件配置文件名称,收件人地址,主题,正文和查询。查询结果将作为 CSV 文件附加到电子邮件。 4. 创建一个作业来定期运行存储过程并发送电子邮件。在 SQL Server Management Studio ,右键单击“SQL Server代理”文件夹,然后选择“新建作业”。在“步骤”选项卡添加一个步骤,该步骤将运行存储过程并发送电子邮件。在“计划”选项卡设置作业运行的频率和时间。 通过这些步骤,您可以在 SQL Server 2008 R2 查询数据并定期发送电子邮件。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值