SQLServer中发送HTML格式邮件的方法

断断续续的烟雨给江南披上了一件白色的纱衣,这件飘若浮云,清净如水的嫁纱,迷蒙了往昔,模糊了过去。我开始在其中憧憬,永远的置身于这种氛围中,让世俗的纠缠远离。

sql server 发送html格式的邮件,参考代码如下:

   DECLARE @tableHTML NVARCHAR(MAX) ;
   -- 获取当前系统时间,和数据统计的时间
   set @d_nowdate = convert(datetime,convert(varchar(10),dateadd(day,-1,getdate()),120),120);

   -- 如果有数据则发送
    if exists (select top 1 * from t_table1(nolock) where d_rq=@d_nowdate)
   begin
    set @str_subject='某某'+convert(varchar(10),@d_nowdate,120)+'净值.';
    SET @tableHTML = N'<H1>某某</H1><br>目前测试中<br><table border="1">' +
         N'<tr><th>日期</th><th>基金代码</th><th>基金名称</th><th>净值</th><th>累计净值</th></tr>' +
       CAST ( (select convert(varchar(10),@d_nowdate,120) as 'td','',VC_JJDM as 'td','',Vc_jjmc as 'td','',EN_JJDWJZ as 'td','',EN_LJJZ as 'td'
          from t_table1 t left join t_table2 tt on t.VC_JJDM = tt.C_FUNDCODE 
         where d_rq=@d_nowdate order by Vc_jjmc,VC_JJDM
          FOR XML PATH('tr'), ELEMENTS-- TYPE 
          ) AS NVARCHAR(MAX) ) + N'</table>';

    -- 发送邮件
    exec @i_result = msdb.dbo.sp_send_dbmail
           @profile_name = 'Profile-Mail',
           @recipients = '邮箱地址1;邮箱2;邮箱3', 
           @subject = @str_subject,
           @body = @tableHTML,
           @body_format = 'HTML';
   end

邮件效果如下:

某某净值

目前测试中

日期

基金代码

基金名称

净值

累计净值

2013-12-20

111111

AAAAA

0.98300000

0.98300000

2013-12-20

222222

BBBBB

1.04900000

1.04900000

2013-12-20

333333

CCCCC

0.64000000

0.64000000

2013-12-20

444444

DDDDD

0.99400000

0.99400000

2013-12-20

555555

EEEEE

1.05700000

1.05700000

2013-12-20

666666

FFFFF

0.73400000

0.73400000

本文SQLServer中发送HTML格式邮件的方法到此结束。人生如棋,仅有舍弃一些棋子,才能换得一生的平静和幸福。上帝是公平的,冬天里失去的东西,到春天的时候会还给你;这方面舍弃的东西,在另一方面会补给你。舍与得,其实是一个无限循环的圈。越敢舍,越能得;越愿舍,越易得。舍得之间,人生迥异,以舍为得,妙用无穷!小编再次感谢大家对我们的支持!

您可能有感兴趣的文章
SqlServer生成连续数字根据指定的数字操作

SQLServer中JSON文档型数据的查询问题如何解决

SQLServer备份数据库的完整步骤

在SQLServer中如何使用TryCatch处理异常的示例详解

SQLServer序列SEQUENCE用法介绍