Thor Logo dbatools

Remove-DbaDbMailAccount

View Source
Mikey Bronowski (@MikeyBronowski), bronowski.it
Windows, Linux, macOS

Synopsis

Removes Database Mail accounts from SQL Server instances

Description

Permanently deletes Database Mail accounts from the specified SQL Server instances, removing them from the MSDB database configuration.
This command is useful when decommissioning obsolete email accounts, cleaning up after application retirement, or consolidating accounts during email system migrations.
When used without pipeline input, it automatically retrieves accounts using Get-DbaDbMailAccount with the provided parameters before removal.
Returns detailed status information for each removal operation, including success/failure status and any error messages encountered.

Syntax

Remove-DbaDbMailAccount
    [-SqlInstance] <DbaInstanceParameter[]>
    [-SqlCredential <PSCredential>]
    [-Account <String[]>]
    [-ExcludeAccount <String[]>]
    [-EnableException]
    [-WhatIf]
    [-Confirm]
    [<CommonParameters>]

Remove-DbaDbMailAccount -InputObject <MailAccount[]>
    [-EnableException]
    [-WhatIf]
    [-Confirm]
    [<CommonParameters>]

 

Examples

 

Example: 1
PS C:\> Remove-DbaDbMailAccount -SqlInstance localhost, localhost\namedinstance

Removes all database mail accounts on the localhost, localhost\namedinstance instances.

Example: 2
PS C:\> Remove-DbaDbMailAccount -SqlInstance localhost -Account MyDatabaseMailAccount

Removes MyDatabaseMailAccount database mail account on the localhost.

Example: 3
PS C:\> Get-DbaDbMailAccount -SqlInstance SRV1 | Out-GridView -Title 'Select database mail account(s) to drop' -OutputMode Multiple | Remove-DbaDbMailAccount

Using a pipeline this command gets all database mail accounts on SRV1, lets the user select those to remove and then removes the selected database mail accounts.

Required Parameters

-SqlInstance

The target SQL Server instance or instances.

PropertyValue
Alias
RequiredTrue
Pipelinefalse
Default Value
-InputObject

Accepts Database Mail account objects from the pipeline, typically from Get-DbaDbMailAccount.
Use this approach when you need to filter or review accounts before removal using PowerShell pipeline operations.
Provides more flexibility than specifying account names directly.

PropertyValue
Alias
RequiredTrue
Pipelinetrue (ByValue)
Default Value

Optional Parameters

-SqlCredential

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.

PropertyValue
Alias
RequiredFalse
Pipelinefalse
Default Value
-Account

Specifies one or more Database Mail account names to remove from the SQL Server instance.
Use this when you need to remove specific accounts rather than all accounts on the server.
Accepts multiple account names as a string array for bulk removal operations.

PropertyValue
Alias
RequiredFalse
Pipelinefalse
Default Value
-ExcludeAccount

Specifies Database Mail account names to exclude from removal when processing all accounts on the instance.
Use this when you want to remove most accounts but keep certain ones active for ongoing operations.
Only applies when the Account parameter is not specified.

PropertyValue
Alias
RequiredFalse
Pipelinefalse
Default Value
-EnableException

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.

PropertyValue
Alias
RequiredFalse
Pipelinefalse
Default ValueFalse
-WhatIf

Shows what would happen if the command were to run. No actions are actually performed.

PropertyValue
Aliaswi
RequiredFalse
Pipelinefalse
Default Value
-Confirm

Prompts you for confirmation before executing any changing operations within the command.
This is the default. Use -Confirm:$false to suppress these prompts.

PropertyValue
Aliascf
RequiredFalse
Pipelinefalse
Default Value