| Author | Chrissy LeMaire (@cl), netnerds.net | 
| Availability | Windows, Linux, macOS | 
Want to see the source code for this command? Check out New-DbaAgentAlert on GitHub.
Want to see the Bill Of Health for this command? Check out New-DbaAgentAlert.
Creates SQL Server Agent alerts for automated monitoring and notification of errors, performance conditions, or system events
Creates new SQL Server Agent alerts that monitor for specific error severities, message IDs, performance conditions, or WMI events. Alerts can automatically notify operators via email, pager, or net send when triggered, and optionally execute jobs in response to the monitored condition. Supports configurable notification delays to prevent alert spam and can target specific databases or system-wide monitoring scenarios.
New-DbaAgentAlert
    [-SqlInstance] <DbaInstanceParameter[]>
    [[-SqlCredential] <PSCredential>]
    [-Alert] <String>
    [[-Category] <String>]
    [[-Database] <String>]
    [[-Operator] <String[]>]
    [[-DelayBetweenResponses] <Int32>]
    [-Disabled]
    [[-EventDescriptionKeyword] <String>]
    [[-EventSource] <String>]
    [[-JobId] <String>]
    [[-Severity] <Int32>]
    [[-MessageId] <Int32>]
    [[-NotificationMessage] <String>]
    [[-PerformanceCondition] <String>]
    [[-WmiEventNamespace] <String>]
    [[-WmiEventQuery] <String>]
    [[-NotifyMethod] <String>]
    [-EnableException]
    [-WhatIf]
    [-Confirm]
    [<CommonParameters>]
PS C:\> $parms = @{
SqlInstance           = "sql01"
Severity              = 18
Alert                 = "Severity 018 - Nonfatal Internal Error"
DelayBetweenResponses = 60
NotifyMethod          = "NotifyEmail"
}
PS C:\> $alert = New-DbaAgentAlert @parms
Creates a new alert for severity 18 with the name Severity 018 - Nonfatal Internal Error.
It will send an email to the default operator and wait 60 seconds before sending another email.
The target SQL Server instance or instances 
| Alias | |
| Required | True | 
| Pipeline | true (ByValue) | 
| Default Value | 
Specifies the name for the new SQL Server Agent alert. Must be unique within the SQL Server instance.
Use descriptive names that clearly identify the alert's purpose, such as 'High Severity Errors' or 'Database Full'. 
| Alias | |
| Required | True | 
| Pipeline | false | 
| Default Value | 
Login to the target instance using alternative credentials. Accepts PowerShell credentials (Get-Credential).
Windows Authentication, SQL Server Authentication, Active Directory - Password, and Active Directory - Integrated are all supported.
For MFA support, please use Connect-DbaInstance.
| Alias | |
| Required | False | 
| Pipeline | false | 
| Default Value | 
Assigns the alert to a specific category for organization and management purposes.
Categories help group related alerts together in SQL Server Management Studio and can be used for filtering in reports.
| Alias | |
| Required | False | 
| Pipeline | false | 
| Default Value | 
Restricts the alert to monitor events occurring only in the specified database.
Leave blank to monitor all databases on the instance, or specify a database name to limit scope and reduce false positives.
| Alias | |
| Required | False | 
| Pipeline | false | 
| Default Value | 
Specifies which SQL Server Agent operators will receive notifications when this alert fires.
The operators must already exist and be configured with valid email addresses, pager numbers, or net send addresses.
| Alias | |
| Required | False | 
| Pipeline | false | 
| Default Value | 
Sets the minimum time in seconds between alert notifications to prevent notification spam.
Use higher values like 300-900 seconds for recurring issues to avoid overwhelming operators with repeated alerts.
| Alias | |
| Required | False | 
| Pipeline | false | 
| Default Value | 60 | 
Creates the alert in a disabled state, preventing it from triggering until manually enabled.
Useful when setting up alerts during maintenance windows or when you need to configure notifications before activating monitoring.
| Alias | |
| Required | False | 
| Pipeline | false | 
| Default Value | False | 
Filters alert triggers to only events containing this keyword in the error message text.
Use this to create targeted alerts for specific error conditions like 'deadlock', 'timeout', or 'corruption' within broader error categories.
| Alias | |
| Required | False | 
| Pipeline | false | 
| Default Value | 
Identifies the source application or component for WMI event monitoring.
Required when creating WMI-based alerts to specify which system component's events should trigger the alert.
| Alias | |
| Required | False | 
| Pipeline | false | 
| Default Value | 
Specifies the GUID of a SQL Server Agent job to automatically execute when the alert fires.
Use this for automated responses like running diagnostics, performing cleanup, or triggering failover procedures.
| Alias | |
| Required | False | 
| Pipeline | false | 
| Default Value | 00000000-0000-0000-0000-000000000000 | 
Sets the SQL Server error severity level that triggers this alert, ranging from 0-25.
Common values include 16-18 for user errors, 19-21 for resource issues, and 22-25 for system errors requiring immediate attention.
| Alias | |
| Required | False | 
| Pipeline | false | 
| Default Value | 0 | 
Creates an alert that triggers on a specific SQL Server error message number.
Use this for precise monitoring of known error conditions like message 9002 (transaction log full) or 825 (read-retry errors).
| Alias | |
| Required | False | 
| Pipeline | false | 
| Default Value | 0 | 
Defines custom text to include in alert notifications sent to operators.
Use this to provide context, troubleshooting steps, or escalation procedures specific to this alert condition.
| Alias | |
| Required | False | 
| Pipeline | false | 
| Default Value | 
Defines a performance counter condition that triggers the alert when threshold values are exceeded.
Specify conditions like 'SQLServer:General Statistics|Logins/sec|>|100' to monitor performance metrics and respond to resource issues.
| Alias | |
| Required | False | 
| Pipeline | false | 
| Default Value | 
Specifies the WMI namespace to monitor for events, typically 'root\cimv2' for system events.
Required when creating WMI-based alerts to monitor Windows system events, hardware failures, or application-specific WMI providers.
| Alias | |
| Required | False | 
| Pipeline | false | 
| Default Value | 
Defines the WQL (WMI Query Language) query that determines which WMI events trigger the alert.
Use queries like 'SELECT * FROM Win32_VolumeChangeEvent' to monitor specific system events outside of SQL Server's direct control.
| Alias | |
| Required | False | 
| Pipeline | false | 
| Default Value | 
The method to use to notify the user of the alert. Valid values are 'None', 'NotifyEmail', 'Pager', 'NetSend', 'NotifyAll'. It is NotifyAll by default.
The Pager and net send options will be removed from SQL Server Agent in a future version of Microsoft SQL Server.
Avoid using these features in new development work, and plan to modify applications that currently use these features.
| Alias | |
| Required | False | 
| Pipeline | false | 
| Default Value | NotifyAll | 
| Accepted Values | None,NotifyEmail,Pager,NetSend,NotifyAll | 
By default, when something goes wrong we try to catch it, interpret it and give you a friendly warning message.
This avoids overwhelming you with "sea of red" exceptions, but is inconvenient because it basically disables advanced scripting.
Using this switch turns this "nice by default" feature off and enables you to catch exceptions with your own try/catch.
| Alias | |
| Required | False | 
| Pipeline | false | 
| Default Value | False | 
Shows what would happen if the command were to run. No actions are actually performed.
| Alias | wi | 
| Required | False | 
| Pipeline | false | 
| Default Value | 
Prompts you for confirmation before executing any changing operations within the command.
| Alias | cf | 
| Required | False | 
| Pipeline | false | 
| Default Value |