关于Sql sp_send_dbmail 中一个小BUG

暂时理解为一个小BUG,目前不知道如何处理。

在配置完数据库邮件服务后,提升相应代理权限,能正常发送邮件,包括后备的邮件服务器队列都正常。

主要问题处在:当使用一个无效的邮件地址(拼错应该是正常现象),由于我使用了重试机制(50次,每5分种一次),因此会出现,抄送名单中其他所有人都会不停的接收邮件,而服务器认为此邮件未执行成功,其实是部分成功,因其中一个出现错误。


在此情况下,我不知道如何来解决,当时唯一能做的就是,修改重试次数为1.


后来想了下,在网上找了一段代码,主要是清除邮件队列里的内容,不过我i当时未能尝试成功,因当时msdb报事务日志错,同时为了快速解决问题。


  1. EXEC msdb.dbo.sysmail_delete_mailitems_sp   --删除队列容,需要指定参数,时间等
  2. EXEC msdb.dbo.sysmail_delete_log_sp    --删除日志
  3. DELETE FROM msdb.dbo.sysmail_attachments   --删除邮件附件。


msdb事务日志出错致上面语句执行不能功,后来只能小批量删 msdb.dbo.sysmail_attachments   where 每次100,该表全删除后,可以收缩数据库,同时上述语句再执行时不报错误 。

上述修补机制还需进一步验证。



你可能感兴趣的:(关于Sql sp_send_dbmail 中一个小BUG)