我正在尝试使用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' ;
如何解决此问题?
答案 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