SQL Server中发送HTML格式邮件的方法
sqlserver发送html格式的邮件,参考代码如下:
DECLARE@tableHTMLNVARCHAR(MAX);
--获取当前系统时间,和数据统计的时间
set@d_nowdate=convert(datetime,convert(varchar(10),dateadd(day,-1,getdate()),120),120);
--如果有数据则发送
ifexists(selecttop1*fromt_table1(nolock)whered_rq=@d_nowdate)
begin
set@str_subject='某某'+convert(varchar(10),@d_nowdate,120)+'净值.';
SET@tableHTML=N'<H1>某某</H1><br>目前测试中<br><tableborder="1">'+
N'<tr><th>日期</th><th>基金代码</th><th>基金名称</th><th>净值</th><th>累计净值</th></tr>'+
CAST((selectconvert(varchar(10),@d_nowdate,120)as'td','',VC_JJDMas'td','',Vc_jjmcas'td','',EN_JJDWJZas'td','',EN_LJJZas'td'
fromt_table1tleftjoint_table2ttont.VC_JJDM=tt.C_FUNDCODE
whered_rq=@d_nowdateorderbyVc_jjmc,VC_JJDM
FORXMLPATH('tr'),ELEMENTS--TYPE
)ASNVARCHAR(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