邮件已排队但未在SQL Server 2014中提供

时间:2017-04-10 07:55:24

标签: sql-server email sql-server-2005 sql-server-2014-express

我正在尝试使用SQL Server 2014通过电子邮件发送SQL查询的结果。问题是电子邮件已排队,但未传递给收件人。与服务器的连接存在一些问题。我得到的描述是:

  

由于邮件服务器故障,无法将邮件发送给收件人。 (使用帐户1发送邮件(2017-04-05T16:05:09)。例外消息:无法连接到邮件服务器。(连接尝试失败,因为连接方在一段时间后没有正确响应,或已建立连接失败,因为已连接的主机无法响应74.125.130.109:25)。

我的代码是:

EXECUTE msdb.dbo.sysmail_add_account_sp  
     @account_name = 'MIS_Automation_Project',  
     @description = 'Mail account for office files.',  
     @email_address = 'my_email_address',  
     @display_name = 'MIS_Automation',  
     @mailserver_name = 'smtp.gmail.com' ;  

-- Create a Database Mail profile  
EXECUTE msdb.dbo.sysmail_add_profile_sp  
    @profile_name = 'MIS_Automation',  
    @description = 'Profile used for mis automation project' ;

-- Add the account to the profile  
EXECUTE msdb.dbo.sysmail_add_profileaccount_sp  
    @profile_name = 'MIS_Automation',  
    @account_name = 'MIS_Automation_Project',  
    @sequence_number =1 ;

-- Grant access to the profile to the DBMailUsers role  
EXECUTE msdb.dbo.sysmail_add_principalprofile_sp  
    @profile_name = 'MIS_Automation',  
    @principal_name = 'guest',  
    @is_default = 1 ; 

DECLARE @xml NVARCHAR(MAX)
DECLARE @body NVARCHAR(MAX)

SET @xml = CAST(( SELECT [clno] AS 'td','',[clname] AS 'td','',
[cladd] AS 'td'
FROM  Client  
FOR XML PATH('tr'), ELEMENTS ) AS NVARCHAR(MAX))

SET @body ='<html><body><H3>Client Information</H3>
<table border = 1> 
<tr>
<th> Client No </th> <th> Client Name </th> <th> Client Address </th>
</tr>'  

SET @body = @body + @xml +'</table></body></html>'

EXEC msdb.dbo.sp_send_dbmail
    @profile_name = 'MIS_Automation', -- replace with your SQL Database Mail Profile 
    @body = @body,
    @body_format ='HTML',
    @recipients = 'recipient', -- replace with your email address
    @subject = 'E-mail in Tabular Format' ;

如何解决此问题?

1 个答案:

答案 0 :(得分:0)

我最好的猜测是您使用了错误的身份验证方法连接到谷歌SMTP服务器(错误消息表明您尝试在端口25上连接但谷歌使用安全的SSL端口465,据我记得)。此外,没有凭证通过,因此它尝试使用匿名身份验证,我认为这也不适用于gmail。

因此,对于故障排除,您可以从一些简单的验证开始:

请通过SSMS连接到您的SQL Server并导航到管理 - &gt;数据库邮件 - &gt;配置数据库邮件 - &gt;管理数据库邮件帐户和配置文件 - &gt;查看,更改或删除现有帐户并验证其中的设置。您应该启用SSL(指定端口465)和基本身份验证。

我的另一个想法是防火墙会阻止连接,因此第二点值得验证。

如果它仍然不起作用,那么文章可能会有用: https://technet.microsoft.com/en-us/library/ms187540%28v=sql.105%29.aspx?f=255&MSPPError=-2147217396