{"id":16094,"date":"2021-04-23T11:43:52","date_gmt":"2021-04-23T09:43:52","guid":{"rendered":"https:\/\/www.dbi-services.com\/blog\/sql-server-get-email-notifications-for-error-log-entries\/"},"modified":"2025-10-01T11:53:42","modified_gmt":"2025-10-01T09:53:42","slug":"sql-server-get-email-notifications-for-error-log-entries","status":"publish","type":"post","link":"https:\/\/www.dbi-services.com\/blog\/sql-server-get-email-notifications-for-error-log-entries\/","title":{"rendered":"SQL Server: Get email notifications for Error Log entries"},"content":{"rendered":"<h4>Introduction<\/h4>\n<p>In a <a href=\"https:\/\/www.dbi-services.com\/blog\/sql-server-audit-changes-on-instance-configuration-linked-servers-and-agent-jobs\/\">previous<\/a> blog post, I did a T-SQL script reading Audit files to send emails with valuable information about instance changes.<br \/>\nIn this one, you will see how to get nice emails from critical errors or specific events occurring on the instance using the ErrorLog.<\/p>\n<p>A common best practice for any DBA is to configure SQL Server Agent Alert for errors with severity 17 to 25.<a href=\"https:\/\/www.dbi-services.com\/blog\/wp-content\/uploads\/sites\/2\/2022\/04\/Blog20_1_Alerts.png\"><img loading=\"lazy\" decoding=\"async\" class=\"aligncenter wp-image-49369\" src=\"https:\/\/www.dbi-services.com\/blog\/wp-content\/uploads\/sites\/2\/2022\/04\/Blog20_1_Alerts.png\" alt=\"\" width=\"504\" height=\"196\" \/><\/a><\/p>\n<p>Alerts are also often set for less critical errors like &#8220;Login failed&#8221; (severity level 14).<br \/>\nEmails sent from Alerts are very basic and looks like this:<a href=\"https:\/\/www.dbi-services.com\/blog\/wp-content\/uploads\/sites\/2\/2022\/04\/Blog20_2_Email_LoginFailed.png\"><img loading=\"lazy\" decoding=\"async\" class=\"aligncenter wp-image-49372\" src=\"https:\/\/www.dbi-services.com\/blog\/wp-content\/uploads\/sites\/2\/2022\/04\/Blog20_2_Email_LoginFailed.png\" alt=\"\" width=\"605\" height=\"211\" \/><\/a><\/p>\n<p>All these errors are written to the SQL Server <a href=\"https:\/\/docs.microsoft.com\/en-us\/troubleshoot\/sql\/admin\/manage-error-log\">Error Log<\/a> file.<img loading=\"lazy\" decoding=\"async\" class=\"aligncenter wp-image-49381\" src=\"https:\/\/www.dbi-services.com\/blog\/wp-content\/uploads\/sites\/2\/2022\/04\/Blog20_3_ErrorLog.png\" alt=\"\" width=\"756\" height=\"242\" \/><\/p>\n<p>The text message for these error messages that are logged into the Error Log can be found in the <a href=\"https:\/\/docs.microsoft.com\/en-us\/sql\/relational-databases\/system-catalog-views\/messages-for-errors-catalog-views-sys-messages?view=sql-server-ver15\">sys.messages<\/a> view.<\/p>\n<div>\n<div id=\"highlighter_32309\" class=\"syntaxhighlighter  sql\">\n<table border=\"0\" cellspacing=\"0\" cellpadding=\"0\">\n<tbody>\n<tr>\n<td class=\"gutter\">\n<div class=\"line number1 index0 alt2\">1<\/div>\n<div class=\"line number2 index1 alt1\">2<\/div>\n<div class=\"line number3 index2 alt2\">3<\/div>\n<div class=\"line number4 index3 alt1\">4<\/div>\n<div class=\"line number5 index4 alt2\">5<\/div>\n<div class=\"line number6 index5 alt1\">6<\/div>\n<div class=\"line number7 index6 alt2\">7<\/div>\n<\/td>\n<td class=\"code\">\n<div class=\"container\">\n<div class=\"line number1 index0 alt2\"><code class=\"sql keyword\">select<\/code> <code class=\"sql plain\">message_id, severity, text<\/code><\/div>\n<div class=\"line number2 index1 alt1\"><code class=\"sql keyword\">from<\/code> <code class=\"sql plain\">sys.messages <\/code><\/div>\n<div class=\"line number3 index2 alt2\"><code class=\"sql keyword\">where<\/code> <code class=\"sql plain\">(severity <\/code><code class=\"sql color1\">between<\/code> <code class=\"sql plain\">18 <\/code><code class=\"sql color1\">and<\/code> <code class=\"sql plain\">21<\/code><\/div>\n<div class=\"line number4 index3 alt1\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0<\/code><code class=\"sql color1\">or<\/code> <code class=\"sql plain\">severity = 14)<\/code><\/div>\n<div class=\"line number5 index4 alt2\"><code class=\"sql spaces\">\u00a0\u00a0<\/code><code class=\"sql color1\">and<\/code> <code class=\"sql plain\">is_event_logged = 1 <\/code><\/div>\n<div class=\"line number6 index5 alt1\"><code class=\"sql spaces\">\u00a0\u00a0<\/code><code class=\"sql color1\">and<\/code> <code class=\"sql plain\">language_id = 1033<\/code><\/div>\n<div class=\"line number7 index6 alt2\"><code class=\"sql keyword\">order<\/code> <code class=\"sql keyword\">by<\/code> <code class=\"sql plain\">severity;<\/code><\/div>\n<\/div>\n<\/td>\n<\/tr>\n<\/tbody>\n<\/table>\n<\/div>\n<\/div>\n<p>This query returns 174 rows on SQL Server version 2019.<a href=\"https:\/\/www.dbi-services.com\/blog\/wp-content\/uploads\/sites\/2\/2022\/04\/Blog20_4_sysmessages.png\"><img loading=\"lazy\" decoding=\"async\" class=\"aligncenter wp-image-49382\" src=\"https:\/\/www.dbi-services.com\/blog\/wp-content\/uploads\/sites\/2\/2022\/04\/Blog20_4_sysmessages.png\" alt=\"\" width=\"755\" height=\"633\" \/><\/a><\/p>\n<p>The error log files can be read using the stored procedure sp_reaerrorlog.<\/p>\n<h4>Searching in the Error Log in SQL<\/h4>\n<p>The aim of the T-SQL script I am writing now is to replace Alerts with a job running every 5 minutes on my instance that will send me emails based on some messages I will define.<\/p>\n<p>Knowing all the information we&#8217;ve seen before, I can build a table variable with the text that I want to look for in the ErrorLog, whether it is critical errors or informational messages.<\/p>\n<div>\n<div id=\"highlighter_272394\" class=\"syntaxhighlighter  sql\">\n<table border=\"0\" cellspacing=\"0\" cellpadding=\"0\">\n<tbody>\n<tr>\n<td class=\"gutter\">\n<div class=\"line number1 index0 alt2\">1<\/div>\n<div class=\"line number2 index1 alt1\">2<\/div>\n<div class=\"line number3 index2 alt2\">3<\/div>\n<div class=\"line number4 index3 alt1\">4<\/div>\n<div class=\"line number5 index4 alt2\">5<\/div>\n<div class=\"line number6 index5 alt1\">6<\/div>\n<div class=\"line number7 index6 alt2\">7<\/div>\n<div class=\"line number8 index7 alt1\">8<\/div>\n<div class=\"line number9 index8 alt2\">9<\/div>\n<div class=\"line number10 index9 alt1\">10<\/div>\n<div class=\"line number11 index10 alt2\">11<\/div>\n<div class=\"line number12 index11 alt1\">12<\/div>\n<\/td>\n<td class=\"code\">\n<div class=\"container\">\n<div class=\"line number1 index0 alt2\"><code class=\"sql keyword\">DECLARE<\/code> <code class=\"sql plain\">@errorlog_definition <\/code><code class=\"sql keyword\">TABLE<\/code><code class=\"sql plain\">(<\/code><\/div>\n<div class=\"line number2 index1 alt1\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"sql plain\">error_category <\/code><code class=\"sql keyword\">varchar<\/code><code class=\"sql plain\">(150)<\/code><\/div>\n<div class=\"line number3 index2 alt2\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"sql plain\">, error_pattern <\/code><code class=\"sql keyword\">varchar<\/code><code class=\"sql plain\">(1000)<\/code><\/div>\n<div class=\"line number4 index3 alt1\"><code class=\"sql plain\">)<\/code><\/div>\n<div class=\"line number5 index4 alt2\"><code class=\"sql keyword\">insert<\/code> <code class=\"sql keyword\">into<\/code> <code class=\"sql plain\">@errorlog_definition<\/code><\/div>\n<div class=\"line number6 index5 alt1\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"sql keyword\">values<\/code> <code class=\"sql plain\">(<\/code><code class=\"sql string\">'Database Write Latency'<\/code><code class=\"sql plain\">, <\/code><code class=\"sql string\">'%I\/O requests taking longer than%seconds to complete%'<\/code><code class=\"sql plain\">)<\/code><\/div>\n<div class=\"line number7 index6 alt2\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"sql plain\">,(<\/code><code class=\"sql string\">'Database Write Latency'<\/code><code class=\"sql plain\">, <\/code><code class=\"sql string\">'%cleaned up%bufs with%in%ms%for db%'<\/code><code class=\"sql plain\">)<\/code><\/div>\n<div class=\"line number8 index7 alt1\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"sql plain\">,(<\/code><code class=\"sql string\">'Database Write Latency'<\/code><code class=\"sql plain\">, <\/code><code class=\"sql string\">'%average%'<\/code><code class=\"sql plain\">)<\/code><\/div>\n<div class=\"line number9 index8 alt2\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"sql plain\">,(<\/code><code class=\"sql string\">'Database Write Latency'<\/code><code class=\"sql plain\">, <\/code><code class=\"sql string\">'%last target outstanding:%avgWriteLatency%'<\/code><code class=\"sql plain\">)<\/code><\/div>\n<div class=\"line number10 index9 alt1\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"sql plain\">,(<\/code><code class=\"sql string\">'Database Write Error Disk Full'<\/code><code class=\"sql plain\">, <\/code><code class=\"sql string\">'Could not allocate%'<\/code><code class=\"sql plain\">)<\/code><\/div>\n<div class=\"line number11 index10 alt2\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"sql plain\">,(<\/code><code class=\"sql string\">'Database Login Failure'<\/code><code class=\"sql plain\">, <\/code><code class=\"sql string\">'%Login Failed%'<\/code><code class=\"sql plain\">)<\/code><\/div>\n<div class=\"line number12 index11 alt1\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"sql plain\">,(<\/code><code class=\"sql string\">'SQL Server starting'<\/code><code class=\"sql plain\">, <\/code><code class=\"sql string\">'SQL Server is starting%'<\/code><code class=\"sql plain\">)<\/code><\/div>\n<\/div>\n<\/td>\n<\/tr>\n<\/tbody>\n<\/table>\n<\/div>\n<\/div>\n<p>The first column is the type of event I want to be emailed about and will be used in the email title.<\/p>\n<p>The current error log entries are inserted in another table variable.<\/p>\n<div>\n<div id=\"highlighter_838845\" class=\"syntaxhighlighter  sql\">\n<table border=\"0\" cellspacing=\"0\" cellpadding=\"0\">\n<tbody>\n<tr>\n<td class=\"gutter\">\n<div class=\"line number1 index0 alt2\">1<\/div>\n<div class=\"line number2 index1 alt1\">2<\/div>\n<\/td>\n<td class=\"code\">\n<div class=\"container\">\n<div class=\"line number1 index0 alt2\"><code class=\"sql keyword\">insert<\/code> <code class=\"sql keyword\">into<\/code> <code class=\"sql plain\">@errorlog<\/code><\/div>\n<div class=\"line number2 index1 alt1\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"sql keyword\">exec<\/code> <code class=\"sql plain\">sp_readerrorlog 0<\/code><\/div>\n<\/div>\n<\/td>\n<\/tr>\n<\/tbody>\n<\/table>\n<\/div>\n<\/div>\n<p>Now, using a CROSS APPPY I can get only the Error Log entries matching my messages patterns.<\/p>\n<div>\n<div id=\"highlighter_289322\" class=\"syntaxhighlighter  sql\">\n<table border=\"0\" cellspacing=\"0\" cellpadding=\"0\">\n<tbody>\n<tr>\n<td class=\"gutter\">\n<div class=\"line number1 index0 alt2\">1<\/div>\n<div class=\"line number2 index1 alt1\">2<\/div>\n<div class=\"line number3 index2 alt2\">3<\/div>\n<div class=\"line number4 index3 alt1\">4<\/div>\n<div class=\"line number5 index4 alt2\">5<\/div>\n<div class=\"line number6 index5 alt1\">6<\/div>\n<div class=\"line number7 index6 alt2\">7<\/div>\n<\/td>\n<td class=\"code\">\n<div class=\"container\">\n<div class=\"line number1 index0 alt2\"><code class=\"sql keyword\">select<\/code> <code class=\"sql plain\">e.LogDate, e.ProcessInfo, e.Text, c.error_category<\/code><\/div>\n<div class=\"line number2 index1 alt1\"><code class=\"sql keyword\">from<\/code> <code class=\"sql plain\">@errorlog <\/code><code class=\"sql keyword\">AS<\/code> <code class=\"sql plain\">e<\/code><\/div>\n<div class=\"line number3 index2 alt2\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"sql color1\">cross<\/code> <code class=\"sql plain\">apply (<\/code><\/div>\n<div class=\"line number4 index3 alt1\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"sql keyword\">select<\/code> <code class=\"sql plain\">*<\/code><\/div>\n<div class=\"line number5 index4 alt2\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"sql keyword\">from<\/code> <code class=\"sql plain\">@errorlog_definition <\/code><code class=\"sql keyword\">AS<\/code> <code class=\"sql plain\">d<\/code><\/div>\n<div class=\"line number6 index5 alt1\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"sql keyword\">where<\/code> <code class=\"sql plain\">e.Text <\/code><code class=\"sql color1\">like<\/code> <code class=\"sql plain\">d.error_pattern<\/code><\/div>\n<div class=\"line number7 index6 alt2\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"sql plain\">) <\/code><code class=\"sql keyword\">AS<\/code> <code class=\"sql plain\">c<\/code><\/div>\n<\/div>\n<\/td>\n<\/tr>\n<\/tbody>\n<\/table>\n<\/div>\n<\/div>\n<p><a href=\"https:\/\/www.dbi-services.com\/blog\/wp-content\/uploads\/sites\/2\/2022\/04\/Blog20_5_query.png\"><img loading=\"lazy\" decoding=\"async\" class=\"aligncenter wp-image-49383\" src=\"https:\/\/www.dbi-services.com\/blog\/wp-content\/uploads\/sites\/2\/2022\/04\/Blog20_5_query.png\" alt=\"\" width=\"854\" height=\"132\" \/><\/a><\/p>\n<p>I managed to get only the Error Log entries I want. Entries are categorized and I decided not to send just one email every time the job runs but once for every category.<\/p>\n<p>I did this with cursors. Here is the whole script if you want to try it.<\/p>\n<h4>Script<\/h4>\n<div>\n<div id=\"highlighter_24271\" class=\"syntaxhighlighter  sql\">\n<table border=\"0\" cellspacing=\"0\" cellpadding=\"0\">\n<tbody>\n<tr>\n<td class=\"gutter\">\n<div class=\"line number1 index0 alt2\">1<\/div>\n<div class=\"line number2 index1 alt1\">2<\/div>\n<div class=\"line number3 index2 alt2\">3<\/div>\n<div class=\"line number4 index3 alt1\">4<\/div>\n<div class=\"line number5 index4 alt2\">5<\/div>\n<div class=\"line number6 index5 alt1\">6<\/div>\n<div class=\"line number7 index6 alt2\">7<\/div>\n<div class=\"line number8 index7 alt1\">8<\/div>\n<div class=\"line number9 index8 alt2\">9<\/div>\n<div class=\"line number10 index9 alt1\">10<\/div>\n<div class=\"line number11 index10 alt2\">11<\/div>\n<div class=\"line number12 index11 alt1\">12<\/div>\n<div class=\"line number13 index12 alt2\">13<\/div>\n<div class=\"line number14 index13 alt1\">14<\/div>\n<div class=\"line number15 index14 alt2\">15<\/div>\n<div class=\"line number16 index15 alt1\">16<\/div>\n<div class=\"line number17 index16 alt2\">17<\/div>\n<div class=\"line number18 index17 alt1\">18<\/div>\n<div class=\"line number19 index18 alt2\">19<\/div>\n<div class=\"line number20 index19 alt1\">20<\/div>\n<div class=\"line number21 index20 alt2\">21<\/div>\n<div class=\"line number22 index21 alt1\">22<\/div>\n<div class=\"line number23 index22 alt2\">23<\/div>\n<div class=\"line number24 index23 alt1\">24<\/div>\n<div class=\"line number25 index24 alt2\">25<\/div>\n<div class=\"line number26 index25 alt1\">26<\/div>\n<div class=\"line number27 index26 alt2\">27<\/div>\n<div class=\"line number28 index27 alt1\">28<\/div>\n<div class=\"line number29 index28 alt2\">29<\/div>\n<div class=\"line number30 index29 alt1\">30<\/div>\n<div class=\"line number31 index30 alt2\">31<\/div>\n<div class=\"line number32 index31 alt1\">32<\/div>\n<div class=\"line number33 index32 alt2\">33<\/div>\n<div class=\"line number34 index33 alt1\">34<\/div>\n<div class=\"line number35 index34 alt2\">35<\/div>\n<div class=\"line number36 index35 alt1\">36<\/div>\n<div class=\"line number37 index36 alt2\">37<\/div>\n<div class=\"line number38 index37 alt1\">38<\/div>\n<div class=\"line number39 index38 alt2\">39<\/div>\n<div class=\"line number40 index39 alt1\">40<\/div>\n<div class=\"line number41 index40 alt2\">41<\/div>\n<div class=\"line number42 index41 alt1\">42<\/div>\n<div class=\"line number43 index42 alt2\">43<\/div>\n<div class=\"line number44 index43 alt1\">44<\/div>\n<div class=\"line number45 index44 alt2\">45<\/div>\n<div class=\"line number46 index45 alt1\">46<\/div>\n<div class=\"line number47 index46 alt2\">47<\/div>\n<div class=\"line number48 index47 alt1\">48<\/div>\n<div class=\"line number49 index48 alt2\">49<\/div>\n<div class=\"line number50 index49 alt1\">50<\/div>\n<div class=\"line number51 index50 alt2\">51<\/div>\n<div class=\"line number52 index51 alt1\">52<\/div>\n<div class=\"line number53 index52 alt2\">53<\/div>\n<div class=\"line number54 index53 alt1\">54<\/div>\n<div class=\"line number55 index54 alt2\">55<\/div>\n<div class=\"line number56 index55 alt1\">56<\/div>\n<div class=\"line number57 index56 alt2\">57<\/div>\n<div class=\"line number58 index57 alt1\">58<\/div>\n<div class=\"line number59 index58 alt2\">59<\/div>\n<div class=\"line number60 index59 alt1\">60<\/div>\n<div class=\"line number61 index60 alt2\">61<\/div>\n<div class=\"line number62 index61 alt1\">62<\/div>\n<div class=\"line number63 index62 alt2\">63<\/div>\n<div class=\"line number64 index63 alt1\">64<\/div>\n<div class=\"line number65 index64 alt2\">65<\/div>\n<div class=\"line number66 index65 alt1\">66<\/div>\n<div class=\"line number67 index66 alt2\">67<\/div>\n<div class=\"line number68 index67 alt1\">68<\/div>\n<div class=\"line number69 index68 alt2\">69<\/div>\n<div class=\"line number70 index69 alt1\">70<\/div>\n<div class=\"line number71 index70 alt2\">71<\/div>\n<div class=\"line number72 index71 alt1\">72<\/div>\n<div class=\"line number73 index72 alt2\">73<\/div>\n<div class=\"line number74 index73 alt1\">74<\/div>\n<div class=\"line number75 index74 alt2\">75<\/div>\n<div class=\"line number76 index75 alt1\">76<\/div>\n<div class=\"line number77 index76 alt2\">77<\/div>\n<div class=\"line number78 index77 alt1\">78<\/div>\n<div class=\"line number79 index78 alt2\">79<\/div>\n<div class=\"line number80 index79 alt1\">80<\/div>\n<div class=\"line number81 index80 alt2\">81<\/div>\n<div class=\"line number82 index81 alt1\">82<\/div>\n<div class=\"line number83 index82 alt2\">83<\/div>\n<div class=\"line number84 index83 alt1\">84<\/div>\n<div class=\"line number85 index84 alt2\">85<\/div>\n<div class=\"line number86 index85 alt1\">86<\/div>\n<div class=\"line number87 index86 alt2\">87<\/div>\n<div class=\"line number88 index87 alt1\">88<\/div>\n<div class=\"line number89 index88 alt2\">89<\/div>\n<div class=\"line number90 index89 alt1\">90<\/div>\n<div class=\"line number91 index90 alt2\">91<\/div>\n<div class=\"line number92 index91 alt1\">92<\/div>\n<div class=\"line number93 index92 alt2\">93<\/div>\n<div class=\"line number94 index93 alt1\">94<\/div>\n<div class=\"line number95 index94 alt2\">95<\/div>\n<div class=\"line number96 index95 alt1\">96<\/div>\n<div class=\"line number97 index96 alt2\">97<\/div>\n<div class=\"line number98 index97 alt1\">98<\/div>\n<div class=\"line number99 index98 alt2\">99<\/div>\n<div class=\"line number100 index99 alt1\">100<\/div>\n<div class=\"line number101 index100 alt2\">101<\/div>\n<div class=\"line number102 index101 alt1\">102<\/div>\n<div class=\"line number103 index102 alt2\">103<\/div>\n<div class=\"line number104 index103 alt1\">104<\/div>\n<div class=\"line number105 index104 alt2\">105<\/div>\n<div class=\"line number106 index105 alt1\">106<\/div>\n<div class=\"line number107 index106 alt2\">107<\/div>\n<div class=\"line number108 index107 alt1\">108<\/div>\n<div class=\"line number109 index108 alt2\">109<\/div>\n<div class=\"line number110 index109 alt1\">110<\/div>\n<div class=\"line number111 index110 alt2\">111<\/div>\n<div class=\"line number112 index111 alt1\">112<\/div>\n<div class=\"line number113 index112 alt2\">113<\/div>\n<div class=\"line number114 index113 alt1\">114<\/div>\n<div class=\"line number115 index114 alt2\">115<\/div>\n<div class=\"line number116 index115 alt1\">116<\/div>\n<div class=\"line number117 index116 alt2\">117<\/div>\n<div class=\"line number118 index117 alt1\">118<\/div>\n<div class=\"line number119 index118 alt2\">119<\/div>\n<div class=\"line number120 index119 alt1\">120<\/div>\n<div class=\"line number121 index120 alt2\">121<\/div>\n<div class=\"line number122 index121 alt1\">122<\/div>\n<div class=\"line number123 index122 alt2\">123<\/div>\n<div class=\"line number124 index123 alt1\">124<\/div>\n<div class=\"line number125 index124 alt2\">125<\/div>\n<div class=\"line number126 index125 alt1\">126<\/div>\n<div class=\"line number127 index126 alt2\">127<\/div>\n<div class=\"line number128 index127 alt1\">128<\/div>\n<div class=\"line number129 index128 alt2\">129<\/div>\n<div class=\"line number130 index129 alt1\">130<\/div>\n<div class=\"line number131 index130 alt2\">131<\/div>\n<div class=\"line number132 index131 alt1\">132<\/div>\n<div class=\"line number133 index132 alt2\">133<\/div>\n<div class=\"line number134 index133 alt1\">134<\/div>\n<div class=\"line number135 index134 alt2\">135<\/div>\n<\/td>\n<td class=\"code\">\n<div class=\"container\">\n<div class=\"line number1 index0 alt2\"><code class=\"sql comments\">--\u00a0 Job frequency<\/code><\/div>\n<div class=\"line number2 index1 alt1\"><code class=\"sql keyword\">DECLARE<\/code> <code class=\"sql plain\">@CheckPeriodInMinute <\/code><code class=\"sql keyword\">int<\/code> <code class=\"sql plain\">= 5<\/code><\/div>\n<div class=\"line number3 index2 alt2\"><\/div>\n<div class=\"line number4 index3 alt1\"><code class=\"sql comments\">--\u00a0 Variables<\/code><\/div>\n<div class=\"line number5 index4 alt2\"><code class=\"sql keyword\">DECLARE<\/code> <code class=\"sql plain\">@colldate datetime\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0 <\/code><\/div>\n<div class=\"line number6 index5 alt1\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"sql plain\">, @object <\/code><code class=\"sql keyword\">varchar<\/code><code class=\"sql plain\">(1024)<\/code><\/div>\n<div class=\"line number7 index6 alt2\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"sql plain\">, @HTML_footer <\/code><code class=\"sql keyword\">varchar<\/code><code class=\"sql plain\">(<\/code><code class=\"sql keyword\">max<\/code><code class=\"sql plain\">)\u00a0 <\/code><\/div>\n<div class=\"line number8 index7 alt1\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"sql plain\">, @HTML_header <\/code><code class=\"sql keyword\">varchar<\/code><code class=\"sql plain\">(<\/code><code class=\"sql keyword\">max<\/code><code class=\"sql plain\">)\u00a0 <\/code><\/div>\n<div class=\"line number9 index8 alt2\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"sql plain\">, @HTML <\/code><code class=\"sql keyword\">varchar<\/code><code class=\"sql plain\">(<\/code><code class=\"sql keyword\">max<\/code><code class=\"sql plain\">)\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0 <\/code><\/div>\n<div class=\"line number10 index9 alt1\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"sql plain\">, @HTML_part <\/code><code class=\"sql keyword\">varchar<\/code><code class=\"sql plain\">(<\/code><code class=\"sql keyword\">max<\/code><code class=\"sql plain\">)\u00a0\u00a0\u00a0 <\/code><\/div>\n<div class=\"line number11 index10 alt2\"><\/div>\n<div class=\"line number12 index11 alt1\"><code class=\"sql keyword\">DECLARE<\/code> <code class=\"sql plain\">@errorlog <\/code><code class=\"sql keyword\">TABLE<\/code><code class=\"sql plain\">(<\/code><\/div>\n<div class=\"line number13 index12 alt2\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"sql plain\">LogDate datetime<\/code><\/div>\n<div class=\"line number14 index13 alt1\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"sql plain\">, ProcessInfo <\/code><code class=\"sql keyword\">varchar<\/code><code class=\"sql plain\">(32)<\/code><\/div>\n<div class=\"line number15 index14 alt2\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"sql plain\">, Text <\/code><code class=\"sql keyword\">varchar<\/code><code class=\"sql plain\">(<\/code><code class=\"sql keyword\">max<\/code><code class=\"sql plain\">)<\/code><\/div>\n<div class=\"line number16 index15 alt1\"><code class=\"sql plain\">)<\/code><\/div>\n<div class=\"line number17 index16 alt2\"><code class=\"sql keyword\">DECLARE<\/code> <code class=\"sql plain\">@notifiable_errors <\/code><code class=\"sql keyword\">table<\/code><code class=\"sql plain\">(<\/code><\/div>\n<div class=\"line number18 index17 alt1\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"sql plain\">LogDate <\/code><code class=\"sql keyword\">varchar<\/code><code class=\"sql plain\">(19)<\/code><\/div>\n<div class=\"line number19 index18 alt2\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"sql plain\">, ProcessInfo <\/code><code class=\"sql keyword\">varchar<\/code><code class=\"sql plain\">(32)<\/code><\/div>\n<div class=\"line number20 index19 alt1\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"sql plain\">, Text <\/code><code class=\"sql keyword\">varchar<\/code><code class=\"sql plain\">(1024)<\/code><\/div>\n<div class=\"line number21 index20 alt2\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"sql plain\">, error_category <\/code><code class=\"sql keyword\">varchar<\/code><code class=\"sql plain\">(150)<\/code><\/div>\n<div class=\"line number22 index21 alt1\"><code class=\"sql plain\">)<\/code><\/div>\n<div class=\"line number23 index22 alt2\"><\/div>\n<div class=\"line number24 index23 alt1\"><code class=\"sql keyword\">SELECT<\/code> <code class=\"sql plain\">@HTML_header=<\/code><code class=\"sql string\">'<\/code><\/div>\n<div class=\"line number25 index24 alt2\"><code class=\"sql string\">&lt;head&gt;<\/code><\/div>\n<div class=\"line number26 index25 alt1\"><code class=\"sql string\">&lt;style type=\"text\/css\"&gt;<\/code><\/div>\n<div class=\"line number27 index26 alt2\"><code class=\"sql string\">table {border: 1px solid #1C6EA4;background-color: #EEEEEE;width: 100%;text-align: left;border-collapse: collapse;}<\/code><\/div>\n<div class=\"line number28 index27 alt1\"><code class=\"sql string\">table td, table th {border: 1px solid #AAAAAA;padding: 3px 2px;}<\/code><\/div>\n<div class=\"line number29 index28 alt2\"><code class=\"sql string\">table tbody td {font-size: 13px;}<\/code><\/div>\n<div class=\"line number30 index29 alt1\"><code class=\"sql string\">table thead {background: #1C6EA4;border-bottom: 2px solid #444444;}<\/code><\/div>\n<div class=\"line number31 index30 alt2\"><code class=\"sql string\">table thead th {font-size: 15px;font-weight: bold;color: #FFFFFF;border-left: 2px solid #D0E4F5;}<\/code><\/div>\n<div class=\"line number32 index31 alt1\"><code class=\"sql string\">table thead th:first-child {border-left: none;}<\/code><\/div>\n<div class=\"line number33 index32 alt2\"><code class=\"sql string\">h1\u00a0\u00a0\u00a0\u00a0\u00a0 {font:bold 16pt Arial,Helvetica,Geneva,sans-serif; color:#336699; background-color:White; border-bottom:1px solid #cccc99; margin-top:15pt; margin-bottom:0pt; padding:0px 0px 0px 0px;}<\/code><\/div>\n<div class=\"line number34 index33 alt1\"><code class=\"sql string\">&lt;\/style&gt;<\/code><\/div>\n<div class=\"line number35 index34 alt2\"><code class=\"sql string\">&lt;\/head&gt;<\/code><\/div>\n<div class=\"line number36 index35 alt1\"><code class=\"sql string\">&lt;body&gt;<\/code><\/div>\n<div class=\"line number37 index36 alt2\"><code class=\"sql string\">&lt;a name=\"top\"&gt;&lt;\/a&gt;'<\/code><\/div>\n<div class=\"line number38 index37 alt1\"><\/div>\n<div class=\"line number39 index38 alt2\"><code class=\"sql keyword\">set<\/code> <code class=\"sql plain\">@HTML_footer=<\/code><code class=\"sql string\">'&lt;p&gt;&lt;i&gt;Executed on '<\/code><code class=\"sql plain\">+<\/code><code class=\"sql color2\">convert<\/code><code class=\"sql plain\">(<\/code><code class=\"sql keyword\">varchar<\/code><code class=\"sql plain\">,getdate(),120)+<\/code><code class=\"sql string\">' from server \"'<\/code><code class=\"sql plain\">+<\/code><code class=\"sql color2\">isnull<\/code><code class=\"sql plain\">(<\/code><code class=\"sql color2\">convert<\/code><code class=\"sql plain\">(<\/code><code class=\"sql keyword\">varchar<\/code><code class=\"sql plain\">(128),@@SERVERNAME),<\/code><code class=\"sql string\">''<\/code><code class=\"sql plain\">)+<\/code><code class=\"sql string\">'\"&lt;\/i&gt;&lt;\/p&gt;'<\/code><\/div>\n<div class=\"line number40 index39 alt1\"><\/div>\n<div class=\"line number41 index40 alt2\"><code class=\"sql comments\">--\u00a0 ----<\/code><\/div>\n<div class=\"line number42 index41 alt1\"><code class=\"sql keyword\">DECLARE<\/code> <code class=\"sql plain\">@errorlog_definition <\/code><code class=\"sql keyword\">TABLE<\/code><code class=\"sql plain\">(<\/code><\/div>\n<div class=\"line number43 index42 alt2\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"sql plain\">error_category <\/code><code class=\"sql keyword\">varchar<\/code><code class=\"sql plain\">(150)<\/code><\/div>\n<div class=\"line number44 index43 alt1\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"sql plain\">, error_pattern <\/code><code class=\"sql keyword\">varchar<\/code><code class=\"sql plain\">(1000)<\/code><\/div>\n<div class=\"line number45 index44 alt2\"><code class=\"sql plain\">)<\/code><\/div>\n<div class=\"line number46 index45 alt1\"><code class=\"sql keyword\">insert<\/code> <code class=\"sql keyword\">into<\/code> <code class=\"sql plain\">@errorlog_definition<\/code><\/div>\n<div class=\"line number47 index46 alt2\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"sql keyword\">values<\/code> <code class=\"sql plain\">(<\/code><code class=\"sql string\">'Database Write Latency'<\/code><code class=\"sql plain\">, <\/code><code class=\"sql string\">'%I\/O requests taking longer than%seconds to complete%'<\/code><code class=\"sql plain\">)<\/code><\/div>\n<div class=\"line number48 index47 alt1\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"sql plain\">,(<\/code><code class=\"sql string\">'Database Write Latency'<\/code><code class=\"sql plain\">, <\/code><code class=\"sql string\">'%cleaned up%bufs with%in%ms%for db%'<\/code><code class=\"sql plain\">)<\/code><\/div>\n<div class=\"line number49 index48 alt2\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"sql plain\">,(<\/code><code class=\"sql string\">'Database Write Latency'<\/code><code class=\"sql plain\">, <\/code><code class=\"sql string\">'%average%'<\/code><code class=\"sql plain\">)<\/code><\/div>\n<div class=\"line number50 index49 alt1\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"sql plain\">,(<\/code><code class=\"sql string\">'Database Write Latency'<\/code><code class=\"sql plain\">, <\/code><code class=\"sql string\">'%last target outstanding:%avgWriteLatency%'<\/code><code class=\"sql plain\">)<\/code><\/div>\n<div class=\"line number51 index50 alt2\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"sql plain\">,(<\/code><code class=\"sql string\">'Database Write Error Disk Full'<\/code><code class=\"sql plain\">, <\/code><code class=\"sql string\">'Could not allocate%'<\/code><code class=\"sql plain\">)<\/code><\/div>\n<div class=\"line number52 index51 alt1\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"sql plain\">,(<\/code><code class=\"sql string\">'Database Login Failure'<\/code><code class=\"sql plain\">, <\/code><code class=\"sql string\">'%Login Failed%'<\/code><code class=\"sql plain\">)<\/code><\/div>\n<div class=\"line number53 index52 alt2\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"sql plain\">,(<\/code><code class=\"sql string\">'SQL Server starting'<\/code><code class=\"sql plain\">, <\/code><code class=\"sql string\">'SQL Server is starting%'<\/code><code class=\"sql plain\">)<\/code><\/div>\n<div class=\"line number54 index53 alt1\"><\/div>\n<div class=\"line number55 index54 alt2\"><code class=\"sql keyword\">insert<\/code> <code class=\"sql keyword\">into<\/code> <code class=\"sql plain\">@errorlog<\/code><\/div>\n<div class=\"line number56 index55 alt1\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"sql keyword\">exec<\/code> <code class=\"sql plain\">sp_readerrorlog 0<\/code><\/div>\n<div class=\"line number57 index56 alt2\"><\/div>\n<div class=\"line number58 index57 alt1\"><code class=\"sql comments\">-- Get Error Log entries matching pattern (like)<\/code><\/div>\n<div class=\"line number59 index58 alt2\"><code class=\"sql keyword\">insert<\/code> <code class=\"sql keyword\">into<\/code> <code class=\"sql plain\">@notifiable_errors<\/code><\/div>\n<div class=\"line number60 index59 alt1\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"sql keyword\">select<\/code> <code class=\"sql plain\">e.LogDate, e.ProcessInfo, e.Text, c.error_category<\/code><\/div>\n<div class=\"line number61 index60 alt2\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"sql keyword\">from<\/code> <code class=\"sql plain\">@errorlog <\/code><code class=\"sql keyword\">AS<\/code> <code class=\"sql plain\">e<\/code><\/div>\n<div class=\"line number62 index61 alt1\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"sql color1\">cross<\/code> <code class=\"sql plain\">apply (<\/code><\/div>\n<div class=\"line number63 index62 alt2\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"sql keyword\">select<\/code> <code class=\"sql plain\">*<\/code><\/div>\n<div class=\"line number64 index63 alt1\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"sql keyword\">from<\/code> <code class=\"sql plain\">@errorlog_definition <\/code><code class=\"sql keyword\">AS<\/code> <code class=\"sql plain\">d<\/code><\/div>\n<div class=\"line number65 index64 alt2\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"sql keyword\">where<\/code> <code class=\"sql plain\">e.Text <\/code><code class=\"sql color1\">like<\/code> <code class=\"sql plain\">d.error_pattern<\/code><\/div>\n<div class=\"line number66 index65 alt1\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"sql plain\">) <\/code><code class=\"sql keyword\">AS<\/code> <code class=\"sql plain\">c<\/code><\/div>\n<div class=\"line number67 index66 alt2\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"sql keyword\">where<\/code> <code class=\"sql plain\">LogDate &gt; DATEADD(<\/code><code class=\"sql keyword\">MINUTE<\/code><code class=\"sql plain\">, -@CheckPeriodInMinute, GETDATE())<\/code><\/div>\n<div class=\"line number68 index67 alt1\"><\/div>\n<div class=\"line number69 index68 alt2\"><code class=\"sql comments\">-- If any rows to process<\/code><\/div>\n<div class=\"line number70 index69 alt1\"><code class=\"sql plain\">if @@ROWCOUNT&gt;0<\/code><\/div>\n<div class=\"line number71 index70 alt2\"><code class=\"sql keyword\">begin<\/code><\/div>\n<div class=\"line number72 index71 alt1\"><\/div>\n<div class=\"line number73 index72 alt2\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"sql keyword\">DECLARE<\/code> <code class=\"sql plain\">@logdate datetime<\/code><\/div>\n<div class=\"line number74 index73 alt1\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"sql keyword\">DECLARE<\/code> <code class=\"sql plain\">@processInfo <\/code><code class=\"sql keyword\">varchar<\/code><code class=\"sql plain\">(32)<\/code><\/div>\n<div class=\"line number75 index74 alt2\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"sql keyword\">DECLARE<\/code> <code class=\"sql plain\">@Text <\/code><code class=\"sql keyword\">varchar<\/code><code class=\"sql plain\">(<\/code><code class=\"sql keyword\">MAX<\/code><code class=\"sql plain\">)<\/code><\/div>\n<div class=\"line number76 index75 alt1\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"sql keyword\">DECLARE<\/code> <code class=\"sql plain\">@error_category <\/code><code class=\"sql keyword\">varchar<\/code><code class=\"sql plain\">(150)<\/code><\/div>\n<div class=\"line number77 index76 alt2\"><\/div>\n<div class=\"line number78 index77 alt1\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"sql keyword\">DECLARE<\/code> <code class=\"sql plain\">category_cursor <\/code><code class=\"sql keyword\">CURSOR<\/code> <code class=\"sql keyword\">FOR<\/code><\/div>\n<div class=\"line number79 index78 alt2\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"sql keyword\">select<\/code> <code class=\"sql keyword\">distinct<\/code> <code class=\"sql plain\">error_category<\/code><\/div>\n<div class=\"line number80 index79 alt1\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"sql keyword\">from<\/code> <code class=\"sql plain\">@notifiable_errors<\/code><\/div>\n<div class=\"line number81 index80 alt2\"><\/div>\n<div class=\"line number82 index81 alt1\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"sql keyword\">OPEN<\/code> <code class=\"sql plain\">category_cursor\u00a0 <\/code><\/div>\n<div class=\"line number83 index82 alt2\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"sql keyword\">FETCH<\/code> <code class=\"sql keyword\">NEXT<\/code> <code class=\"sql keyword\">FROM<\/code> <code class=\"sql plain\">category_cursor <\/code><code class=\"sql keyword\">INTO<\/code> <code class=\"sql plain\">@error_category<\/code><\/div>\n<div class=\"line number84 index83 alt1\"><\/div>\n<div class=\"line number85 index84 alt2\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"sql plain\">WHILE @@FETCH_STATUS = 0\u00a0 <\/code><\/div>\n<div class=\"line number86 index85 alt1\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"sql keyword\">BEGIN<\/code><\/div>\n<div class=\"line number87 index86 alt2\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"sql comments\">-- Loops 1 time per category<\/code><\/div>\n<div class=\"line number88 index87 alt1\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><\/div>\n<div class=\"line number89 index88 alt2\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"sql comments\">-- Email Object + HTML Table header<\/code><\/div>\n<div class=\"line number90 index89 alt1\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"sql keyword\">SELECT<\/code> <code class=\"sql plain\">@object = @error_category+<\/code><code class=\"sql string\">' - Last '<\/code><code class=\"sql plain\">+<\/code><code class=\"sql color2\">convert<\/code><code class=\"sql plain\">(<\/code><code class=\"sql keyword\">varchar<\/code><code class=\"sql plain\">(50),@CheckPeriodInMinute)+<\/code><code class=\"sql string\">' min ('<\/code><code class=\"sql plain\">+<\/code><code class=\"sql color2\">convert<\/code><code class=\"sql plain\">(<\/code><code class=\"sql keyword\">varchar<\/code><code class=\"sql plain\">(<\/code><code class=\"sql keyword\">max<\/code><code class=\"sql plain\">),@@servername)+<\/code><code class=\"sql string\">')'<\/code><\/div>\n<div class=\"line number91 index90 alt2\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"sql keyword\">SELECT<\/code> <code class=\"sql plain\">@HTML=@HTML_header+<\/code><code class=\"sql string\">'&lt;h1&gt;'<\/code><code class=\"sql plain\">+@error_category+<\/code><code class=\"sql string\">' (last '<\/code><code class=\"sql plain\">+<\/code><code class=\"sql color2\">convert<\/code><code class=\"sql plain\">(<\/code><code class=\"sql keyword\">varchar<\/code><code class=\"sql plain\">(50),@CheckPeriodInMinute)+<\/code><code class=\"sql string\">' min)&lt;\/h1&gt;'<\/code><\/div>\n<div class=\"line number92 index91 alt1\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><\/div>\n<div class=\"line number93 index92 alt2\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"sql keyword\">SELECT<\/code> <code class=\"sql plain\">@HTML=@HTML+<\/code><code class=\"sql string\">'<\/code><\/div>\n<div class=\"line number94 index93 alt1\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"sql string\">&lt;table&gt;<\/code><\/div>\n<div class=\"line number95 index94 alt2\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"sql string\">&lt;tr&gt;&lt;th&gt;LogDate&lt;\/th&gt;&lt;th&gt;ProcessInfo&lt;\/th&gt;&lt;th&gt;Text&lt;\/th&gt;&lt;\/tr&gt;<\/code><\/div>\n<div class=\"line number96 index95 alt1\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"sql string\">'<\/code><\/div>\n<div class=\"line number97 index96 alt2\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"sql comments\">--\u00a0 ----<\/code><\/div>\n<div class=\"line number98 index97 alt1\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"sql comments\">--\u00a0 Cursor: Get all entries for the current category<\/code><\/div>\n<div class=\"line number99 index98 alt2\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"sql comments\">--\u00a0 Create HTML Table rows<\/code><\/div>\n<div class=\"line number100 index99 alt1\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"sql comments\">--\u00a0 ----<\/code><\/div>\n<div class=\"line number101 index100 alt2\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"sql keyword\">DECLARE<\/code> <code class=\"sql plain\">error_cursor <\/code><code class=\"sql keyword\">CURSOR<\/code> <code class=\"sql keyword\">FOR<\/code><\/div>\n<div class=\"line number102 index101 alt1\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"sql keyword\">select<\/code> <code class=\"sql plain\">LogDate, ProcessInfo, Text<\/code><\/div>\n<div class=\"line number103 index102 alt2\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"sql keyword\">from<\/code> <code class=\"sql plain\">@notifiable_errors<\/code><\/div>\n<div class=\"line number104 index103 alt1\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"sql keyword\">where<\/code> <code class=\"sql plain\">error_category = @error_category<\/code><\/div>\n<div class=\"line number105 index104 alt2\"><\/div>\n<div class=\"line number106 index105 alt1\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"sql keyword\">OPEN<\/code> <code class=\"sql plain\">error_cursor\u00a0 <\/code><\/div>\n<div class=\"line number107 index106 alt2\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"sql keyword\">FETCH<\/code> <code class=\"sql keyword\">NEXT<\/code> <code class=\"sql keyword\">FROM<\/code> <code class=\"sql plain\">error_cursor <\/code><code class=\"sql keyword\">INTO<\/code> <code class=\"sql plain\">@logdate, @processInfo, @Text<\/code><\/div>\n<div class=\"line number108 index107 alt1\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"sql plain\">WHILE @@FETCH_STATUS = 0\u00a0 <\/code><\/div>\n<div class=\"line number109 index108 alt2\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"sql keyword\">BEGIN<\/code><\/div>\n<div class=\"line number110 index109 alt1\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"sql comments\">-- HTML Table rows<\/code><\/div>\n<div class=\"line number111 index110 alt2\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"sql keyword\">select<\/code> <code class=\"sql plain\">@HTML_part = <\/code><code class=\"sql string\">'&lt;tr&gt;&lt;td&gt;'<\/code><code class=\"sql plain\">+<\/code><code class=\"sql color2\">isnull<\/code><code class=\"sql plain\">(<\/code><code class=\"sql color2\">convert<\/code><code class=\"sql plain\">(<\/code><code class=\"sql keyword\">varchar<\/code><code class=\"sql plain\">,@logdate,120),<\/code><code class=\"sql string\">''<\/code><code class=\"sql plain\">)+<\/code><code class=\"sql string\">'&lt;\/td&gt;&lt;td&gt;'<\/code><code class=\"sql plain\">+<\/code><code class=\"sql color2\">isnull<\/code><code class=\"sql plain\">(@processInfo,<\/code><code class=\"sql string\">''<\/code><code class=\"sql plain\">)+<\/code><code class=\"sql string\">'&lt;\/td&gt;&lt;td&gt;'<\/code><code class=\"sql plain\">+<\/code><code class=\"sql color2\">isnull<\/code><code class=\"sql plain\">(@Text,<\/code><code class=\"sql string\">''<\/code><code class=\"sql plain\">)+<\/code><code class=\"sql string\">'&lt;\/td&gt;&lt;\/tr&gt;'<\/code><\/div>\n<div class=\"line number112 index111 alt1\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"sql keyword\">set<\/code> <code class=\"sql plain\">@HTML=@HTML+@HTML_part+<\/code><code class=\"sql string\">'<\/code><\/div>\n<div class=\"line number113 index112 alt2\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"sql string\">'<\/code><\/div>\n<div class=\"line number114 index113 alt1\"><\/div>\n<div class=\"line number115 index114 alt2\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"sql keyword\">FETCH<\/code> <code class=\"sql keyword\">NEXT<\/code> <code class=\"sql keyword\">FROM<\/code> <code class=\"sql plain\">error_cursor <\/code><code class=\"sql keyword\">INTO<\/code> <code class=\"sql plain\">@logdate, @processInfo, @Text;<\/code><\/div>\n<div class=\"line number116 index115 alt1\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"sql keyword\">END<\/code><\/div>\n<div class=\"line number117 index116 alt2\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"sql keyword\">CLOSE<\/code> <code class=\"sql plain\">error_cursor\u00a0 <\/code><\/div>\n<div class=\"line number118 index117 alt1\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"sql keyword\">DEALLOCATE<\/code> <code class=\"sql plain\">error_cursor <\/code><\/div>\n<div class=\"line number119 index118 alt2\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><\/div>\n<div class=\"line number120 index119 alt1\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"sql comments\">-- HTML Table end + send email<\/code><\/div>\n<div class=\"line number121 index120 alt2\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"sql keyword\">set<\/code> <code class=\"sql plain\">@HTML=@HTML+<\/code><code class=\"sql string\">'&lt;\/table&gt;<\/code><\/div>\n<div class=\"line number122 index121 alt1\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"sql string\">'<\/code><code class=\"sql plain\">+@HTML_footer<\/code><\/div>\n<div class=\"line number123 index122 alt2\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0\u00a0<\/code><\/div>\n<div class=\"line number124 index123 alt1\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"sql keyword\">EXEC<\/code> <code class=\"sql plain\">msdb.dbo.sp_send_dbmail<\/code><\/div>\n<div class=\"line number125 index124 alt2\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"sql plain\">@profile_name = <\/code><code class=\"sql string\">'DBA_Profile'<\/code><\/div>\n<div class=\"line number126 index125 alt1\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"sql plain\">, @subject= @object <\/code><\/div>\n<div class=\"line number127 index126 alt2\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"sql plain\">, @recipients = <\/code><code class=\"sql string\">'sql@DBA.local'<\/code><\/div>\n<div class=\"line number128 index127 alt1\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"sql plain\">, @body_format=<\/code><code class=\"sql string\">'html'<\/code><\/div>\n<div class=\"line number129 index128 alt2\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"sql plain\">, @body = @HTML<\/code><\/div>\n<div class=\"line number130 index129 alt1\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0\u00a0<\/code><\/div>\n<div class=\"line number131 index130 alt2\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"sql keyword\">FETCH<\/code> <code class=\"sql keyword\">NEXT<\/code> <code class=\"sql keyword\">FROM<\/code> <code class=\"sql plain\">category_cursor <\/code><code class=\"sql keyword\">INTO<\/code> <code class=\"sql plain\">@error_category;<\/code><\/div>\n<div class=\"line number132 index131 alt1\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"sql keyword\">END<\/code><\/div>\n<div class=\"line number133 index132 alt2\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"sql keyword\">CLOSE<\/code> <code class=\"sql plain\">category_cursor\u00a0 <\/code><\/div>\n<div class=\"line number134 index133 alt1\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"sql keyword\">DEALLOCATE<\/code> <code class=\"sql plain\">category_cursor <\/code><\/div>\n<div class=\"line number135 index134 alt2\"><code class=\"sql keyword\">end<\/code><\/div>\n<\/div>\n<\/td>\n<\/tr>\n<\/tbody>\n<\/table>\n<\/div>\n<\/div>\n<h4>Email examples<\/h4>\n<p>Here are some emails sent by this Job.<\/p>\n<p>On SQL Server start:<a href=\"https:\/\/www.dbi-services.com\/blog\/wp-content\/uploads\/sites\/2\/2022\/04\/Blog20_6_email_start.png\"><img loading=\"lazy\" decoding=\"async\" class=\"aligncenter wp-image-49387\" src=\"https:\/\/www.dbi-services.com\/blog\/wp-content\/uploads\/sites\/2\/2022\/04\/Blog20_6_email_start.png\" alt=\"\" width=\"780\" height=\"252\" \/><\/a>On Failed login:<a href=\"https:\/\/www.dbi-services.com\/blog\/wp-content\/uploads\/sites\/2\/2022\/04\/Blog20_6_email_loginFailed.png\"><img loading=\"lazy\" decoding=\"async\" class=\"aligncenter wp-image-49386\" src=\"https:\/\/www.dbi-services.com\/blog\/wp-content\/uploads\/sites\/2\/2022\/04\/Blog20_6_email_loginFailed.png\" alt=\"\" width=\"780\" height=\"308\" \/><\/a><\/p>\n<h4>Conclusion<\/h4>\n<p>The drawback of this approach is that I have to know exactly what I want to get emailed about. If I don&#8217;t use Agent Alerts I might miss some critical errors.<br \/>\nWhat is nice is that I can look for informational messages and not only errors.<br \/>\nI hope you found this interesting and it gave you some ideas on how to get information from your SQL Server instances.<\/p>\n<p>Written by <a href=\"https:\/\/www.linkedin.com\/in\/steven-naudet-aa540158\/\">Steven Naudet<\/a><\/p>\n","protected":false},"excerpt":{"rendered":"<p>Introduction In a previous blog post, I did a T-SQL script reading Audit files to send emails with valuable information about instance changes. In this one, you will see how to get nice emails from critical errors or specific events occurring on the instance using the ErrorLog. A common best practice for any DBA is [&hellip;]<\/p>\n","protected":false},"author":26,"featured_media":16095,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"_acf_changed":false,"footnotes":""},"categories":[229,99],"tags":[813,2317,2318,2550,521],"type_dbi":[],"class_list":["post-16094","post","type-post","status-publish","format-standard","has-post-thumbnail","hentry","category-database-administration-monitoring","category-sql-server","tag-alerts","tag-email","tag-error-log","tag-sql-server-2","tag-t-sql"],"acf":[],"yoast_head":"<!-- This site is optimized with the Yoast SEO Premium plugin v27.2 (Yoast SEO v27.2) - https:\/\/yoast.com\/product\/yoast-seo-premium-wordpress\/ -->\n<title>SQL Server: Get email notifications for Error Log entries - dbi Blog<\/title>\n<meta name=\"robots\" content=\"index, follow, max-snippet:-1, max-image-preview:large, max-video-preview:-1\" \/>\n<link rel=\"canonical\" href=\"https:\/\/www.dbi-services.com\/blog\/sql-server-get-email-notifications-for-error-log-entries\/\" \/>\n<meta property=\"og:locale\" content=\"en_US\" \/>\n<meta property=\"og:type\" content=\"article\" \/>\n<meta property=\"og:title\" content=\"SQL Server: Get email notifications for Error Log entries\" \/>\n<meta property=\"og:description\" content=\"Introduction In a previous blog post, I did a T-SQL script reading Audit files to send emails with valuable information about instance changes. In this one, you will see how to get nice emails from critical errors or specific events occurring on the instance using the ErrorLog. A common best practice for any DBA is [&hellip;]\" \/>\n<meta property=\"og:url\" content=\"https:\/\/www.dbi-services.com\/blog\/sql-server-get-email-notifications-for-error-log-entries\/\" \/>\n<meta property=\"og:site_name\" content=\"dbi Blog\" \/>\n<meta property=\"article:published_time\" content=\"2021-04-23T09:43:52+00:00\" \/>\n<meta property=\"article:modified_time\" content=\"2025-10-01T09:53:42+00:00\" \/>\n<meta property=\"og:image\" content=\"http:\/\/www.dbi-services.com\/blog\/wp-content\/uploads\/sites\/2\/2022\/04\/Blog20_1_Alerts.png\" \/>\n\t<meta property=\"og:image:width\" content=\"706\" \/>\n\t<meta property=\"og:image:height\" content=\"275\" \/>\n\t<meta property=\"og:image:type\" content=\"image\/png\" \/>\n<meta name=\"author\" content=\"Microsoft Team\" \/>\n<meta name=\"twitter:card\" content=\"summary_large_image\" \/>\n<meta name=\"twitter:label1\" content=\"Written by\" \/>\n\t<meta name=\"twitter:data1\" content=\"Microsoft Team\" \/>\n\t<meta name=\"twitter:label2\" content=\"Est. reading time\" \/>\n\t<meta name=\"twitter:data2\" content=\"5 minutes\" \/>\n<script type=\"application\/ld+json\" class=\"yoast-schema-graph\">{\"@context\":\"https:\/\/schema.org\",\"@graph\":[{\"@type\":\"Article\",\"@id\":\"https:\/\/www.dbi-services.com\/blog\/sql-server-get-email-notifications-for-error-log-entries\/#article\",\"isPartOf\":{\"@id\":\"https:\/\/www.dbi-services.com\/blog\/sql-server-get-email-notifications-for-error-log-entries\/\"},\"author\":{\"name\":\"Microsoft Team\",\"@id\":\"https:\/\/www.dbi-services.com\/blog\/#\/schema\/person\/bfab48333280d616e1170e7369df90a4\"},\"headline\":\"SQL Server: Get email notifications for Error Log entries\",\"datePublished\":\"2021-04-23T09:43:52+00:00\",\"dateModified\":\"2025-10-01T09:53:42+00:00\",\"mainEntityOfPage\":{\"@id\":\"https:\/\/www.dbi-services.com\/blog\/sql-server-get-email-notifications-for-error-log-entries\/\"},\"wordCount\":422,\"commentCount\":0,\"image\":{\"@id\":\"https:\/\/www.dbi-services.com\/blog\/sql-server-get-email-notifications-for-error-log-entries\/#primaryimage\"},\"thumbnailUrl\":\"https:\/\/www.dbi-services.com\/blog\/wp-content\/uploads\/sites\/2\/2022\/04\/Blog20_1_Alerts.png\",\"keywords\":[\"Alerts\",\"email\",\"Error log\",\"SQL Server\",\"T-SQL\"],\"articleSection\":[\"Database Administration &amp; Monitoring\",\"SQL Server\"],\"inLanguage\":\"en-US\",\"potentialAction\":[{\"@type\":\"CommentAction\",\"name\":\"Comment\",\"target\":[\"https:\/\/www.dbi-services.com\/blog\/sql-server-get-email-notifications-for-error-log-entries\/#respond\"]}]},{\"@type\":\"WebPage\",\"@id\":\"https:\/\/www.dbi-services.com\/blog\/sql-server-get-email-notifications-for-error-log-entries\/\",\"url\":\"https:\/\/www.dbi-services.com\/blog\/sql-server-get-email-notifications-for-error-log-entries\/\",\"name\":\"SQL Server: Get email notifications for Error Log entries - dbi Blog\",\"isPartOf\":{\"@id\":\"https:\/\/www.dbi-services.com\/blog\/#website\"},\"primaryImageOfPage\":{\"@id\":\"https:\/\/www.dbi-services.com\/blog\/sql-server-get-email-notifications-for-error-log-entries\/#primaryimage\"},\"image\":{\"@id\":\"https:\/\/www.dbi-services.com\/blog\/sql-server-get-email-notifications-for-error-log-entries\/#primaryimage\"},\"thumbnailUrl\":\"https:\/\/www.dbi-services.com\/blog\/wp-content\/uploads\/sites\/2\/2022\/04\/Blog20_1_Alerts.png\",\"datePublished\":\"2021-04-23T09:43:52+00:00\",\"dateModified\":\"2025-10-01T09:53:42+00:00\",\"author\":{\"@id\":\"https:\/\/www.dbi-services.com\/blog\/#\/schema\/person\/bfab48333280d616e1170e7369df90a4\"},\"breadcrumb\":{\"@id\":\"https:\/\/www.dbi-services.com\/blog\/sql-server-get-email-notifications-for-error-log-entries\/#breadcrumb\"},\"inLanguage\":\"en-US\",\"potentialAction\":[{\"@type\":\"ReadAction\",\"target\":[\"https:\/\/www.dbi-services.com\/blog\/sql-server-get-email-notifications-for-error-log-entries\/\"]}]},{\"@type\":\"ImageObject\",\"inLanguage\":\"en-US\",\"@id\":\"https:\/\/www.dbi-services.com\/blog\/sql-server-get-email-notifications-for-error-log-entries\/#primaryimage\",\"url\":\"https:\/\/www.dbi-services.com\/blog\/wp-content\/uploads\/sites\/2\/2022\/04\/Blog20_1_Alerts.png\",\"contentUrl\":\"https:\/\/www.dbi-services.com\/blog\/wp-content\/uploads\/sites\/2\/2022\/04\/Blog20_1_Alerts.png\",\"width\":706,\"height\":275},{\"@type\":\"BreadcrumbList\",\"@id\":\"https:\/\/www.dbi-services.com\/blog\/sql-server-get-email-notifications-for-error-log-entries\/#breadcrumb\",\"itemListElement\":[{\"@type\":\"ListItem\",\"position\":1,\"name\":\"Accueil\",\"item\":\"https:\/\/www.dbi-services.com\/blog\/\"},{\"@type\":\"ListItem\",\"position\":2,\"name\":\"SQL Server: Get email notifications for Error Log entries\"}]},{\"@type\":\"WebSite\",\"@id\":\"https:\/\/www.dbi-services.com\/blog\/#website\",\"url\":\"https:\/\/www.dbi-services.com\/blog\/\",\"name\":\"dbi Blog\",\"description\":\"\",\"potentialAction\":[{\"@type\":\"SearchAction\",\"target\":{\"@type\":\"EntryPoint\",\"urlTemplate\":\"https:\/\/www.dbi-services.com\/blog\/?s={search_term_string}\"},\"query-input\":{\"@type\":\"PropertyValueSpecification\",\"valueRequired\":true,\"valueName\":\"search_term_string\"}}],\"inLanguage\":\"en-US\"},{\"@type\":\"Person\",\"@id\":\"https:\/\/www.dbi-services.com\/blog\/#\/schema\/person\/bfab48333280d616e1170e7369df90a4\",\"name\":\"Microsoft Team\",\"image\":{\"@type\":\"ImageObject\",\"inLanguage\":\"en-US\",\"@id\":\"https:\/\/secure.gravatar.com\/avatar\/c44a1a792c059f24055763aa77d80a244467f6eef724a8bd13db8d4a350b7a4c?s=96&d=mm&r=g\",\"url\":\"https:\/\/secure.gravatar.com\/avatar\/c44a1a792c059f24055763aa77d80a244467f6eef724a8bd13db8d4a350b7a4c?s=96&d=mm&r=g\",\"contentUrl\":\"https:\/\/secure.gravatar.com\/avatar\/c44a1a792c059f24055763aa77d80a244467f6eef724a8bd13db8d4a350b7a4c?s=96&d=mm&r=g\",\"caption\":\"Microsoft Team\"},\"url\":\"https:\/\/www.dbi-services.com\/blog\/author\/microsoft-team\/\"}]}<\/script>\n<!-- \/ Yoast SEO Premium plugin. -->","yoast_head_json":{"title":"SQL Server: Get email notifications for Error Log entries - dbi Blog","robots":{"index":"index","follow":"follow","max-snippet":"max-snippet:-1","max-image-preview":"max-image-preview:large","max-video-preview":"max-video-preview:-1"},"canonical":"https:\/\/www.dbi-services.com\/blog\/sql-server-get-email-notifications-for-error-log-entries\/","og_locale":"en_US","og_type":"article","og_title":"SQL Server: Get email notifications for Error Log entries","og_description":"Introduction In a previous blog post, I did a T-SQL script reading Audit files to send emails with valuable information about instance changes. In this one, you will see how to get nice emails from critical errors or specific events occurring on the instance using the ErrorLog. A common best practice for any DBA is [&hellip;]","og_url":"https:\/\/www.dbi-services.com\/blog\/sql-server-get-email-notifications-for-error-log-entries\/","og_site_name":"dbi Blog","article_published_time":"2021-04-23T09:43:52+00:00","article_modified_time":"2025-10-01T09:53:42+00:00","og_image":[{"width":706,"height":275,"url":"http:\/\/www.dbi-services.com\/blog\/wp-content\/uploads\/sites\/2\/2022\/04\/Blog20_1_Alerts.png","type":"image\/png"}],"author":"Microsoft Team","twitter_card":"summary_large_image","twitter_misc":{"Written by":"Microsoft Team","Est. reading time":"5 minutes"},"schema":{"@context":"https:\/\/schema.org","@graph":[{"@type":"Article","@id":"https:\/\/www.dbi-services.com\/blog\/sql-server-get-email-notifications-for-error-log-entries\/#article","isPartOf":{"@id":"https:\/\/www.dbi-services.com\/blog\/sql-server-get-email-notifications-for-error-log-entries\/"},"author":{"name":"Microsoft Team","@id":"https:\/\/www.dbi-services.com\/blog\/#\/schema\/person\/bfab48333280d616e1170e7369df90a4"},"headline":"SQL Server: Get email notifications for Error Log entries","datePublished":"2021-04-23T09:43:52+00:00","dateModified":"2025-10-01T09:53:42+00:00","mainEntityOfPage":{"@id":"https:\/\/www.dbi-services.com\/blog\/sql-server-get-email-notifications-for-error-log-entries\/"},"wordCount":422,"commentCount":0,"image":{"@id":"https:\/\/www.dbi-services.com\/blog\/sql-server-get-email-notifications-for-error-log-entries\/#primaryimage"},"thumbnailUrl":"https:\/\/www.dbi-services.com\/blog\/wp-content\/uploads\/sites\/2\/2022\/04\/Blog20_1_Alerts.png","keywords":["Alerts","email","Error log","SQL Server","T-SQL"],"articleSection":["Database Administration &amp; Monitoring","SQL Server"],"inLanguage":"en-US","potentialAction":[{"@type":"CommentAction","name":"Comment","target":["https:\/\/www.dbi-services.com\/blog\/sql-server-get-email-notifications-for-error-log-entries\/#respond"]}]},{"@type":"WebPage","@id":"https:\/\/www.dbi-services.com\/blog\/sql-server-get-email-notifications-for-error-log-entries\/","url":"https:\/\/www.dbi-services.com\/blog\/sql-server-get-email-notifications-for-error-log-entries\/","name":"SQL Server: Get email notifications for Error Log entries - dbi Blog","isPartOf":{"@id":"https:\/\/www.dbi-services.com\/blog\/#website"},"primaryImageOfPage":{"@id":"https:\/\/www.dbi-services.com\/blog\/sql-server-get-email-notifications-for-error-log-entries\/#primaryimage"},"image":{"@id":"https:\/\/www.dbi-services.com\/blog\/sql-server-get-email-notifications-for-error-log-entries\/#primaryimage"},"thumbnailUrl":"https:\/\/www.dbi-services.com\/blog\/wp-content\/uploads\/sites\/2\/2022\/04\/Blog20_1_Alerts.png","datePublished":"2021-04-23T09:43:52+00:00","dateModified":"2025-10-01T09:53:42+00:00","author":{"@id":"https:\/\/www.dbi-services.com\/blog\/#\/schema\/person\/bfab48333280d616e1170e7369df90a4"},"breadcrumb":{"@id":"https:\/\/www.dbi-services.com\/blog\/sql-server-get-email-notifications-for-error-log-entries\/#breadcrumb"},"inLanguage":"en-US","potentialAction":[{"@type":"ReadAction","target":["https:\/\/www.dbi-services.com\/blog\/sql-server-get-email-notifications-for-error-log-entries\/"]}]},{"@type":"ImageObject","inLanguage":"en-US","@id":"https:\/\/www.dbi-services.com\/blog\/sql-server-get-email-notifications-for-error-log-entries\/#primaryimage","url":"https:\/\/www.dbi-services.com\/blog\/wp-content\/uploads\/sites\/2\/2022\/04\/Blog20_1_Alerts.png","contentUrl":"https:\/\/www.dbi-services.com\/blog\/wp-content\/uploads\/sites\/2\/2022\/04\/Blog20_1_Alerts.png","width":706,"height":275},{"@type":"BreadcrumbList","@id":"https:\/\/www.dbi-services.com\/blog\/sql-server-get-email-notifications-for-error-log-entries\/#breadcrumb","itemListElement":[{"@type":"ListItem","position":1,"name":"Accueil","item":"https:\/\/www.dbi-services.com\/blog\/"},{"@type":"ListItem","position":2,"name":"SQL Server: Get email notifications for Error Log entries"}]},{"@type":"WebSite","@id":"https:\/\/www.dbi-services.com\/blog\/#website","url":"https:\/\/www.dbi-services.com\/blog\/","name":"dbi Blog","description":"","potentialAction":[{"@type":"SearchAction","target":{"@type":"EntryPoint","urlTemplate":"https:\/\/www.dbi-services.com\/blog\/?s={search_term_string}"},"query-input":{"@type":"PropertyValueSpecification","valueRequired":true,"valueName":"search_term_string"}}],"inLanguage":"en-US"},{"@type":"Person","@id":"https:\/\/www.dbi-services.com\/blog\/#\/schema\/person\/bfab48333280d616e1170e7369df90a4","name":"Microsoft Team","image":{"@type":"ImageObject","inLanguage":"en-US","@id":"https:\/\/secure.gravatar.com\/avatar\/c44a1a792c059f24055763aa77d80a244467f6eef724a8bd13db8d4a350b7a4c?s=96&d=mm&r=g","url":"https:\/\/secure.gravatar.com\/avatar\/c44a1a792c059f24055763aa77d80a244467f6eef724a8bd13db8d4a350b7a4c?s=96&d=mm&r=g","contentUrl":"https:\/\/secure.gravatar.com\/avatar\/c44a1a792c059f24055763aa77d80a244467f6eef724a8bd13db8d4a350b7a4c?s=96&d=mm&r=g","caption":"Microsoft Team"},"url":"https:\/\/www.dbi-services.com\/blog\/author\/microsoft-team\/"}]}},"_links":{"self":[{"href":"https:\/\/www.dbi-services.com\/blog\/wp-json\/wp\/v2\/posts\/16094","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/www.dbi-services.com\/blog\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/www.dbi-services.com\/blog\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/www.dbi-services.com\/blog\/wp-json\/wp\/v2\/users\/26"}],"replies":[{"embeddable":true,"href":"https:\/\/www.dbi-services.com\/blog\/wp-json\/wp\/v2\/comments?post=16094"}],"version-history":[{"count":2,"href":"https:\/\/www.dbi-services.com\/blog\/wp-json\/wp\/v2\/posts\/16094\/revisions"}],"predecessor-version":[{"id":40609,"href":"https:\/\/www.dbi-services.com\/blog\/wp-json\/wp\/v2\/posts\/16094\/revisions\/40609"}],"wp:featuredmedia":[{"embeddable":true,"href":"https:\/\/www.dbi-services.com\/blog\/wp-json\/wp\/v2\/media\/16095"}],"wp:attachment":[{"href":"https:\/\/www.dbi-services.com\/blog\/wp-json\/wp\/v2\/media?parent=16094"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/www.dbi-services.com\/blog\/wp-json\/wp\/v2\/categories?post=16094"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/www.dbi-services.com\/blog\/wp-json\/wp\/v2\/tags?post=16094"},{"taxonomy":"type","embeddable":true,"href":"https:\/\/www.dbi-services.com\/blog\/wp-json\/wp\/v2\/type_dbi?post=16094"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}