繁体   English   中英

sql server sp_send_dbmail

[英]sql server sp_send_dbmail

我使用SQL Server的sp_send_dbmail存储过程通过数据库发送邮件。

但是当我执行该程序时,它正在关闭db邮件程序。 我尝试通过sysmail_start_sp再次启动它。 但它又在7-8秒内再次关闭。

我试过下面的代码:

EXEC msdb..sp_send_dbmail @profile_name = 'Test',
@recipients = 'abc@gmail.com',
@subject = 'test mail',
@body_format = 'HTML',
@body = 'test mail',
@from_address = 'xyz@yahoo.com'

当我尝试检查错误日志时,我发现以下错误:

信息:

对数据库的读取失败。 原因:错误描述为'此位置不允许空格。'。数据:System.Collections.ListDictionaryInternalTargetSite:Microsoft.SqlServer.Management.SqlIMail.Server.Objects.QueueItem GetQueueItemFromCommand(System.Data.SqlClient.SqlCommand)HelpLink: NULLSource:DatabaseMailEngineStackTrace信息===================

此外,当我检查sql电子邮件日志历史记录时,我发现此错误:

邮件没有排队。 数据库邮件已停止。 使用sysmail_start_sp启动数据库邮件。

每当您尝试从数据库邮件发送测试邮件时; 它会抛出以下错误消息:

消息14641,级别16,状态1,过程sp_send_dbmail,邮件未排队。 数据库邮件已停止。 使用sysmail_start_sp启动数据库邮件。


  1. 首先,确保通过在SSMS中执行以下命令来启用数据库中的Service Broker消息传递:

     SELECT is_broker_enabled FROM sys.databases WHERE name = 'msdb' 

    如果上述查询的结果为0,则激活服务代理。

    激活Service Broker允许将消息传递到数据库。 必须创建Service Broker端点才能从实例外部发送和接收消息。

    要在数据库中激活Service Broker,请使用以下命令:

     USE master ; GO ALTER DATABASE DatabaseName SET ENABLE_BROKER ; GO 
  2. 如果启用了Service Broker,则通过在SQL Server Management Studio中执行以下查询来确认是否启用了数据库邮件:

     sp_configure 'show advanced', 1 GO RECONFIGURE GO sp_configure GO 

    如果结果集将run_value显示为1,则启用数据库邮件。

  3. 如果禁用了“数据库邮件”选项,请运行以下查询以启用它:

     sp_configure 'Database Mail XPs', 1; GO RECONFIGURE; GO sp_configure 'show advanced', 0; GO RECONFIGURE; GO 
  4. 启用数据库邮件后,启动数据库邮件外部程序在msdb数据库上使用下面提到的查询:

     USE msdb ; EXEC msdb.dbo.sysmail_start_sp; 
  5. 要确认已启动数据库邮件外部程序,请运行下面提到的查询:

     EXEC msdb.dbo.sysmail_help_status_sp; 
  6. 如果启动了数据库邮件外部程序,则使用以下语句检查邮件队列的状态:

     EXEC msdb.dbo.sysmail_help_queue_sp @queue_type = 'mail'; 

要解决的问题很少,首先检查以确保通过执行以下操作来启用数据库Mail

SELECT is_broker_enabled FROM sys.databases WHERE name = 'msdb'

如果上述结果为0 ,请按照本指南激活服务代理

如果上面的结果为1 ,则检查数据库邮件的状态,执行以下语句:

EXECUTE dbo.sysmail_help_status_sp

要在邮件主机数据库中启动Database Mail,请在msdb数据库中运行以下命令:

EXECUTE dbo.sysmail_start_sp

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM