Wednesday, September 13, 2017

Add Startup parameter with powershell

http://www.sqlservercentral.com/blogs/erichumphrey/2011/03/31/change-sql-startup-parameters-with-powershell/

##############################################################################
##
## Add-SqlServerStartupParameter
##
## by Eric Humphrey (http://www.erichumphrey.com/category/powershell/)
##
##############################################################################

<#

.SYNOPSIS

Adds an entry to the startup parameters list for all instances of SQL Server
on a computer

.EXAMPLE

PS >Add-SqlServerStartupParameter '-T3226'

#>

param(
    ## The parameter you wish to add
    [Parameter(Mandatory = $true)]
    $StartupParameter
)

$hklmRootNode = "HKLM:\SOFTWARE\Microsoft\Microsoft SQL Server"

$props = Get-ItemProperty "$hklmRootNode\Instance Names\SQL"
$instances = $props.psobject.properties | ?{$_.Value -like 'MSSQL*'} | select Value

$instances | %{
    $inst = $_.Value;
    $regKey = "$hklmRootNode\$inst\MSSQLServer\Parameters"
    $props = Get-ItemProperty $regKey
    $params = $props.psobject.properties | ?{$_.Name -like 'SQLArg*'} | select Name, Value
    #$params | ft -AutoSize
    $hasFlag = $false
    foreach ($param in $params) {
        if($param.Value -eq $StartupParameter) {
            $hasFlag = $true
            break;
        }
    }
    if (-not $hasFlag) {
        "Adding $StartupParameter"
        $newRegProp = "SQLArg"+($params.Count)
        Set-ItemProperty -Path $regKey -Name $newRegProp -Value $StartupParameter
    } else {
        "$StartupParameter already set"
    }
}

Monday, September 11, 2017

Backup Master Key for Encryption - DB Related

USE DBName
BACKUP MASTER KEY TO FILE = 'c:\masterkey'
    ENCRYPTION BY PASSWORD = 'Myw0rld123'

--RESTORE MASTER KEY
--    FROM FILE = 'c:\masterkey'
--    DECRYPTION BY PASSWORD = 'Myw0rld123'
--    ENCRYPTION BY PASSWORD = 'Myw0rld123'

--FORCE