Script SQL Server Backup with Batch Files and PowerShell

This is not our preferred method of deployment, but we have some batch-file based deployments still in active use (most of our deployments are executed via Octopus Deploy, but some of the concepts below are re-usable there too). One of the tasks we perform during a deployment is a database backup prior to schema changes.

The batch file for this is shown below. It simply calls the PowerShell script, bypassing the normal execution policy (so you don’t have to set the global execution policy to be more permissive).

echo Backup Database Starting
explorer "E:\Program Files\Microsoft SQL Server\MSSQL10_50.MSSQLSERVER\MSSQL\Backup"
powershell.exe -ExecutionPolicy Bypass -file "E:\Deployments\db-backup.ps1"
echo Backup Database Done

The contents of “db-backup.ps1” are shown below. There is a simple SQL Script to execute the backup, which is executed by importing the SQLPS module and using the “Invoke-Sqlcmd” cmdlet. (You may need to install the tools to run sql scripts using PowerShell on your server).

Import-Module "C:\Program Files (x86)\Microsoft SQL Server\110\Tools\PowerShell\Modules\SQLPS\sqlps"

$script = @"
DECLARE @script nvarchar(max), @sprint nvarchar(3), @timestamp nvarchar(10), @backuppath nvarchar(250 )

SET @timestamp = CONVERT(char(10), GetDate(), 126)
SET @backuppath = 'E:\Program Files\Microsoft SQL Server\MSSQL10_50.MSSQLSERVER\MSSQL'

    TO DISK = ''' + @backuppath + '\Backup\Your_DB_' + @timestamp + '_Auto.bak'' 
PRINT @script
EXECUTE sp_executesql @script


Invoke-Sqlcmd -ServerInstance "." -Database "master" -Username "user" -Password "pw" -Query $script -QueryTimeout 65334