Cómo comprobar el estado de los mensajes de correo electrónico enviados con Correo electrónico de base de datos (Transact-SQL)

Correo electrónico de base de datos conserva copias de los mensajes de correo electrónico salientes y las muestra en las vistas sysmail_allitems, sysmail_sentitems, sysmail_unsentitems y sysmail_faileditems de la base de datos msdb. El programa externo de Correo electrónico de base de datos registra la actividad y muestra ese registro mediante el registro de eventos de aplicación de Windows y la vista sysmail_event_log de la base de datos msdb. Para comprobar el estado de un mensaje de correo electrónico, ejecute una consulta en esta vista. Los mensajes de correo electrónico tienen cuatro posibles estados: enviado, no enviado, reintentando y error.

Para comprobar el estado de un mensaje de correo electrónico

  1. Selecciones los mensajes que le interesen de la tabla sysmail_allitems mediante mailitem_id o sent_status.

  2. Para comprobar el estado devuelto por el programa externo para los mensajes de correo electrónico, combine las vistas sysmail_allitems y sysmail_event_log en la columna mailitem_id, como se muestra en la sección siguiente.

[!NOTA]

De forma predeterminada, el programa externo no registra información acerca de los mensajes que se enviaron correctamente. Para registrar todos los mensajes, establezca el nivel de registro en detallado mediante la página Configurar parámetros del sistema del Asistente para configuración de Correo electrónico de base de datos.

Ejemplo

En el siguiente ejemplo se muestra información acerca de los mensajes de correo electrónico enviados a danw que el programa externo no ha podido enviar correctamente. La instrucción incluye el asunto, la fecha y la hora en que el programa externo no pudo enviar el mensaje, así como el mensaje de error del registro de Correo electrónico de base de datos.

USE msdb ;
GO

-- Show the subject, the time that the mail item row was last
-- modified, and the log information.
-- Join sysmail_faileditems to sysmail_event_log 
-- on the mailitem_id column.
-- In the WHERE clause list items where danw was in the recipients,
-- copy_recipients, or blind_copy_recipients.
-- These are the items that would have been sent
-- to danw.

SELECT items.subject,
    items.last_mod_date
    ,l.description FROM dbo.sysmail_faileditems as items
INNER JOIN dbo.sysmail_event_log AS l
    ON items.mailitem_id = l.mailitem_id
WHERE items.recipients LIKE '%danw%'  
    OR items.copy_recipients LIKE '%danw%' 
    OR items.blind_copy_recipients LIKE '%danw%'
GO