Хранимая процедура sp_send_dbmail (Transact-SQL)
Область применения: SQL Server Управляемый экземпляр SQL Azure
Отправляет сообщение электронной почты указанным получателям. Сообщение может включать результирующий набор запросов, вложения файлов или оба. Когда почта успешно помещается в очередь Database Mail, sp_send_dbmail
возвращает mailitem_id
сообщение. Эта хранимая процедура находится в msdb
базе данных.
Соглашения о синтаксисе Transact-SQL
Синтаксис
sp_send_dbmail [ [ @profile_name = ] 'profile_name' ]
[ , [ @recipients = ] 'recipients [ ; ...n ]' ]
[ , [ @copy_recipients = ] 'copy_recipient [ ; ...n ]' ]
[ , [ @blind_copy_recipients = ] 'blind_copy_recipient [ ; ...n ]' ]
[ , [ @from_address = ] 'from_address' ]
[ , [ @reply_to = ] 'reply_to' ]
[ , [ @subject = ] N'subject' ]
[ , [ @body = ] N'body' ]
[ , [ @body_format = ] 'body_format' ]
[ , [ @importance = ] 'importance' ]
[ , [ @sensitivity = ] 'sensitivity' ]
[ , [ @file_attachments = ] N'attachment [ ; ...n ]' ]
[ , [ @query = ] N'query' ]
[ , [ @execute_query_database = ] 'execute_query_database' ]
[ , [ @attach_query_result_as_file = ] attach_query_result_as_file ]
[ , [ @query_attachment_filename = ] N'query_attachment_filename' ]
[ , [ @query_result_header = ] query_result_header ]
[ , [ @query_result_width = ] query_result_width ]
[ , [ @query_result_separator = ] 'query_result_separator' ]
[ , [ @exclude_query_output = ] exclude_query_output ]
[ , [ @append_query_error = ] append_query_error ]
[ , [ @query_no_truncate = ] query_no_truncate ]
[ , [ @query_result_no_padding = ] @query_result_no_padding ]
[ , [ @mailitem_id = ] mailitem_id ] [ OUTPUT ]
[ ; ]
Аргументы
[ @profile_name = ] 'profile_name'
Имя профиля для отправки сообщения. @profile_name имеет имя sysname типа с значением по умолчаниюNULL
. @profile_name должно быть именем существующего профиля Database Mail. Если @profile_name не указан, sp_send_dbmail
использует частный профиль по умолчанию для текущего пользователя. Если у пользователя нет частного профиля по умолчанию, sp_send_dbmail
используется общедоступный профиль по умолчанию для msdb
базы данных. Если у пользователя нет закрытого профиля по умолчанию и для базы данных нет общедоступного профиля по умолчанию, необходимо указать @profile_name .
[ @recipients = ] "получатели"
Список адресов электронной почты с разделителями с запятой для отправки сообщения. Список получателей имеет тип varchar(max). Хотя этот параметр является необязательным, необходимо указать хотя бы один из @recipients, @copy_recipients или @blind_copy_recipients или sp_send_dbmail
возвратить ошибку.
[ @copy_recipients = ] 'copy_recipients'
Список адресов электронной почты с разделителями с запятой для копирования сообщения. Список получателей копирования имеет тип varchar(max). Хотя этот параметр является необязательным, необходимо указать хотя бы один из @recipients, @copy_recipients или @blind_copy_recipients или sp_send_dbmail
возвратить ошибку.
[ @blind_copy_recipients = ] 'blind_copy_recipients'
Список адресов электронной почты, разделенных точкой с запятой, для слепой копии сообщения. Список получателей слепой копии имеет тип varchar(max). Хотя этот параметр является необязательным, необходимо указать хотя бы один из @recipients, @copy_recipients или @blind_copy_recipients или sp_send_dbmail
возвратить ошибку.
[ @from_address = ] 'from_address'
Значение "from address" сообщения электронной почты. Это необязательный параметр, используемый для переопределения параметров в профиле электронной почты. Этот параметр имеет тип varchar(max). Параметры безопасности SMTP определяют, будет ли принято переопределение настроек. Если параметр не указан, используется NULL
значение по умолчанию.
[ @reply_to = ] 'reply_to'
Значение "ответ на адрес" сообщения электронной почты. В качестве допустимого значения принимается только один адрес электронной почты. Это необязательный параметр, используемый для переопределения параметров в профиле электронной почты. Этот параметр имеет тип varchar(max). Параметры безопасности SMTP определяют, будет ли принято переопределение настроек. Если параметр не указан, используется NULL
значение по умолчанию.
[ @subject = ] N'subject'
Тема сообщения электронной почты. Тема имеет тип nvarchar(255). Если тема не указана, то по умолчанию устанавливается «Сообщение SQL Server».
[ @body = ] N'body'
Текст сообщения электронной почты. Текст сообщения имеет тип nvarchar(max) с значением по умолчанию NULL
.
[ @body_format = ] 'body_format'
Формат текста сообщения. Параметр имеет тип varchar(20) с значением по умолчанию NULL
. Если установлено значение этого аргумента, то устанавливаются заголовки исходящих сообщений, что указывает на формат текста сообщения. Параметр может содержать одно из следующих значений:
- TEXT (по умолчанию)
- HTML
[ = ] @importance "важность"
Важность сообщения. Параметр имеет тип varchar(6). Параметр может содержать одно из следующих значений:
Low
Normal
(по умолчанию)High
[ = ] @sensitivity 'конфиденциальность'
Конфиденциальность сообщения. Параметр имеет тип varchar(12). Параметр может содержать одно из следующих значений:
Normal
(по умолчанию)Personal
Private
Confidential
[ @file_attachments = ] N'file_attachments'
Список имен файлов, разделенных точкой с запятой, для присоединения к сообщению электронной почты. Файлы в списке должны указываться как абсолютные пути. Список вложений имеет тип nvarchar(max). По умолчанию компонент Database Mail ограничивает размер файлов вложений до 1 МБ на файл.
Внимание
Этот параметр недоступен в Управляемый экземпляр SQL Azure, так как он не может получить доступ к локальной файловой системе.
[ @query = ] N'query'
Выполнение запроса. Результаты запроса могут прикрепляться в виде файла или включаться в текст сообщения электронной почты. Запрос имеет тип nvarchar(max) и может содержать любые допустимые инструкции Transact-SQL. Запрос выполняется в отдельном сеансе, поэтому локальные переменные в вызове sp_send_dbmail
скрипта недоступны для запроса.
При использовании параметра @query субъект, который выполняетсяsp_send_dbmail
, должен быть подключен как отдельный, а не как часть группы, будь то идентификатор Microsoft Entra (ранее Azure Active Directory) или группа Windows Active Directory. Имена входа SQL Server, удостоверения Windows и удостоверения Microsoft Entra могут выполнять запрос, но члены группы не могут, из-за Управляемый экземпляр SQL Azure олицетворения и ограничений EXECUTE AS.
[ @execute_query_database = ] 'execute_query_database'
Контекст базы данных, в котором хранимая процедура выполняет запрос. Параметр имеет имя sysname типа с значением по умолчанию текущей базы данных. Этот параметр применим только при указании @query .
[ @attach_query_result_as_file = ] attach_query_result_as_file
Указывает, возвращается ли результирующий набор запроса как прикрепленный файл. @attach_query_result_as_file имеет тип бита с значением по умолчанию0
.
Если значение равно 0
, результаты запроса включаются в текст сообщения электронной почты после содержимого параметра @body . Если значение равно 1
, результаты возвращаются в виде вложения. Этот параметр применим только при указании @query .
[ @query_attachment_filename = ] N'query_attachment_filename'
Указывает имя файла для результирующего набора вложения запроса. @query_attachment_filename имеет тип nvarchar(255) с значением по умолчаниюNULL
. Этот параметр игнорируется при @attach_query_result_as_file0
. Если @attach_query_result_as_file и этот параметр имеет значение 1
NULL
, Database Mail создает произвольное имя файла.
[ @query_result_header = ] query_result_header
Указывает, включают ли результаты запроса заголовки столбцов. Значение query_result_header имеет бит типа. Если значение равно 1
, результаты запроса содержат заголовки столбцов. Если значение равно 0
, результаты запроса не включают заголовки столбцов. Этот параметр по умолчанию используется 1
. Этот параметр применим только при указании @query .
При настройке @query_result_header и настройке @query_no_truncate 0
1
может возникать следующая ошибка:
Msg 22050, Level 16, State 1, Line 12: Failed to initialize sqlcmd library with error number -2147024809.
[ @query_result_width = ] query_result_width
Ширина строки в символах, используемая для форматирования результатов запроса. @query_result_width имеет тип int с значением по умолчанию256
. Указанное значение должно быть между 10
и 32767
. Этот параметр применим только при указании @query .
[ @query_result_separator = ] 'query_result_separator'
Символ, используемый для разделения столбцов в выходных данных запроса. Разделитель имеет тип char(1). По умолчанию используется ' '
значение (пробел).
[ @exclude_query_output = ] exclude_query_output
Указывает, должен ли результат выполнения запроса возвращаться в сообщении электронной почты. @exclude_query_output бит с значением по умолчанию0
. Если этот параметр имеет значение 0
, выполнение sp_send_dbmail
хранимой процедуры выводит сообщение, возвращаемое в результате выполнения запроса на консоли. Если этот параметр задан 1
, выполнение хранимой процедуры не выводит ни одного из сообщений о выполнении sp_send_dbmail
запроса на консоли.
[ @append_query_error = ] append_query_error
Указывает, следует ли отправлять сообщение электронной почты, когда ошибка возвращается из запроса, указанного в аргументе @query . @append_query_error бит с значением по умолчанию0
. Если этот параметр задан 1
, Database Mail отправляет сообщение электронной почты и содержит сообщение об ошибке запроса в тексте сообщения электронной почты. Если этот параметр задан 0
, Database Mail не отправляет сообщение электронной почты и sp_send_dbmail
заканчивается возвращаемым кодом 1
, указывающим на сбой.
[ @query_no_truncate = ] query_no_truncate
Указывает, следует ли выполнять запрос с параметром, который позволяет избежать усечения типов данных большой длины переменной (varchar(max),nvarchar(max), varbinary(max), xml, text, ntext, image и пользовательских типов данных. При установке результаты запроса не включают заголовки столбцов. Значение @query_no_truncate имеет бит типа. Если значение не 0
указано, столбцы в запросе усечены до 256 символов. Если значение равно 1
, столбцы в запросе не усечены. Этот параметр по умолчанию используется 0
.
Примечание.
При использовании с большими объемами данных параметр @query_no_truncate потребляет дополнительные ресурсы и может снизить производительность сервера.
[ @query_result_no_padding = ] query_result_no_padding
Тип имеет бит. Значение по умолчанию — 0
. Если задано 1
значение, результаты запроса не заполняются, возможно, уменьшая размер файла. Если задан @query_result_no_padding 1
параметр @query_result_width, параметр @query_result_no_padding перезаписывает параметр @query_result_width.
В этом случае ошибка не возникает.
При настройке @query_result_no_padding и предоставлении параметра для @query_no_truncate 1
может возникнуть следующая ошибка:
Msg 22050, Level 16, State 1, Line 0: Failed to execute the query because the @query_result_no_append and @query_no_truncate options are mutually exclusive.
Если @query_result_no_padding задан и задан параметр @query_no_truncate1
, возникает ошибка.
[ @mailitem_id = ] mailitem_id [ ВЫХОДНЫЕ ДАННЫЕ ]
Необязательный выходной mailitem_id
параметр возвращает сообщение. @mailitem_id имеет тип int.
Значения кода возврата
Код возврата 0
означает успешность. Любое другое значение означает неуспешное завершение. Код ошибки для инструкции, которая завершилась сбоем, хранится в переменной @@ERROR
.
Результирующий набор
В случае успешного выполнения возвращает сообщение «Письмо поставлено в очередь».
Замечания
Перед использованием компонент Database Mail необходимо включить с помощью мастера настройки компонента Database Mail или sp_configure
.
sysmail_stop_sp
останавливает Компонент Database Mail, остановив объекты Service Broker, которые использует внешняя программа. sp_send_dbmail
по-прежнему принимает почту при остановке использования sysmail_stop_sp
компонента Database Mail. Чтобы запустить Database Mail, используйте sysmail_start_sp
.
Если @profile не указан, sp_send_dbmail
используется профиль по умолчанию. Если пользователь, отсылающий электронное сообщение, имеет личный профиль по умолчанию, то компонент Database Mail использует этот профиль. Если у пользователя нет частного профиля по умолчанию, sp_send_dbmail
используется общедоступный профиль по умолчанию. Если для пользователя нет частного профиля по умолчанию и нет общедоступного профиля по умолчанию, sp_send_dbmail
возвращает ошибку.
sp_send_dbmail
не поддерживает сообщения электронной почты без содержимого. Чтобы отправить сообщение электронной почты, необходимо указать по крайней мере одну из @body, @query, @file_attachments или @subject. sp_send_dbmail
В противном случае возвращает ошибку.
Для контроля доступа к файлам компонент Database Mail использует контекст безопасности Windows текущего пользователя. Таким образом, пользователи, прошедшие проверку подлинности с помощью проверки подлинности SQL Server, не могут присоединять файлы с помощью @file_attachments. Windows не разрешает SQL Server предоставлять учетные данные с удаленного компьютера на другой удаленный компьютер. Таким образом, Компонент Database Mail может не в состоянии вложить файлы из сетевой папки в тех случаях, когда команда выполняется с компьютера, отличного от компьютера, на котором выполняется SQL Server.
Если указаны оба @query и @file_attachments, и файл не найден, запрос по-прежнему выполняется, но электронная почта не отправляется.
Если указывается запрос, то результирующий набор форматируется как встроенный текст. В результате двоичные данные посылаются в шестнадцатеричном формате.
Параметры @recipients, @copy_recipients и @blind_copy_recipients — это списки адресов электронной почты с запятой. Необходимо указать хотя бы один из этих параметров или sp_send_dbmail
возвратить ошибку.
При выполнении sp_send_dbmail
без контекста транзакции компонент Database Mail запускает и фиксирует неявную транзакцию. При выполнении sp_send_dbmail
из существующей транзакции компонент Database Mail зависит от пользователя от фиксации или отката любых изменений. Он не запускает внутреннюю транзакцию.
Разрешения
Выполнение разрешений для sp_send_dbmail
всех членов роли базы данных DatabaseMailUser в msdb
базе данных по умолчанию. Однако если пользователь, отправляющий сообщение, не имеет разрешения на использование профиля запроса, sp_send_dbmail
возвращает ошибку и не отправляет сообщение.
Примеры
А. Отправка сообщения электронной почты
В этом примере отправляется сообщение электронной почты другому с помощью адреса myfriend@adventure-works.com
электронной почты. Сообщение имеет тему Automated Success Message
. Текст сообщения содержит предложение The stored procedure finished successfully
.
EXEC msdb.dbo.sp_send_dbmail
@profile_name = 'Adventure Works Administrator',
@recipients = 'yourfriend@adventure-works.com',
@body = 'The stored procedure finished successfully.',
@subject = 'Automated Success Message';
B. Отправка сообщения электронной почты с результатами запроса
В этом примере отправляется сообщение электронной почты другому с помощью адреса yourfriend@adventure-works.com
электронной почты. Сообщение содержит тему Work Order Count
и выполняет запрос, показывающий количество рабочих заказов менее DueDate
чем за два дня после 30 апреля 2022 года. Компонент Database Mail прикрепляет результаты в виде текстового файла.
EXEC msdb.dbo.sp_send_dbmail
@profile_name = 'Adventure Works Administrator',
@recipients = 'yourfriend@adventure-works.com',
@query = 'SELECT COUNT(*) FROM AdventureWorks2022.Production.WorkOrder
WHERE DueDate > ''2022-04-30''
AND DATEDIFF(dd, ''2022-04-30'', DueDate) < 2',
@subject = 'Work Order Count',
@attach_query_result_as_file = 1;
C. Отправка сообщения электронной почты HTML
В этом примере отправляется сообщение электронной почты другому с помощью адреса yourfriend@adventure-works.com
электронной почты. Сообщение имеет тему Work Order List
и содержит HTML-документ, который показывает рабочие заказы менее DueDate
чем через два дня после 30 апреля 2022 года. Компонент Database Mail посылает результаты в формате HTML.
DECLARE @tableHTML NVARCHAR(MAX);
SET @tableHTML = N'<H1>Work Order Report</H1>' + N'<table border="1">'
+ N'<tr><th>Work Order ID</th><th>Product ID</th>'
+ N'<th>Name</th><th>Order Qty</th><th>Due Date</th>'
+ N'<th>Expected Revenue</th></tr>'
+ CAST((
SELECT td = wo.WorkOrderID, '',
td = p.ProductID, '',
td = p.Name, '',
td = wo.OrderQty, '',
td = wo.DueDate, '',
td = (p.ListPrice - p.StandardCost) * wo.OrderQty
FROM AdventureWorks.Production.WorkOrder AS wo
INNER JOIN AdventureWorks.Production.Product AS p
ON wo.ProductID = p.ProductID
WHERE DueDate > '2022-04-30'
AND DATEDIFF(dd, '2022-04-30', DueDate) < 2
ORDER BY DueDate ASC,
(p.ListPrice - p.StandardCost) * wo.OrderQty DESC
FOR XML PATH('tr'),
TYPE
) AS NVARCHAR(MAX))
+ N'</table>';
EXEC msdb.dbo.sp_send_dbmail @recipients = 'yourfriend@adventure-works.com',
@subject = 'Work Order List',
@body = @tableHTML,
@body_format = 'HTML';