透過 Powershell 部署 SQL 腳本到多個網站的資料庫

問題

有一套系統,卻克隆 ( Clone )了很多個網站,每個站都是獨立的資料庫,因此部署資料庫時,過去需要人工去每一部部署腳本,此篇則要透過 Powershell 將一個週期開發的 sql 腳本,部署到多個網站的資料庫中。

作法

透過powershell 讀取資料庫設定檔( site.json ) 及 部署的資料庫腳本清單設定的 ( sql.json ) ,並由 sqlcmd 執行資料庫腳本。

安裝 sqlcmd 公用工具 ( 可透過 command line 操作 sql server )

1.至該網站下載 https://docs.microsoft.com/zh-tw/sql/tools/sqlcmd-utility?view=sql-server-ver15

2.開啟 powershell ,透過 sqlcmd 公用程式 來執行 sql 腳本。

& sqlcmd -S "(local)\instance1" -U a -P a -i "c:\temp\sql.sql"

# To call a Win32 executable you want to use the call operator & like this:

建立設定檔

1.建立 database 設定檔 ( site.json )

{
	"servers": [
		{
			"name": "site1",
			"server": "192.168.1.32",
			"db": "CMS",
			"user": "mark",
			"password": "123",
			"switch": "on"
		},
		{
			"name": "site2",
			"server": "192.168.1.31",
			"db": "CMS2",
			"user": "mark",
			"password": "123",
			"switch": "on"
		}
	]
}

2.建立 sql 腳本設定檔( sql.json )

{
	"20210605": [
		{
			"filename": "1.sql",
			"desc": "create customer table"
		},
		{
			"filename": "2.sql",
			"desc": "create customer2 table"
		}
	],
	"20210608": [
		{
			"filename": "3.sql",
			"desc": "create customer3 table"
		},
		{
			"filename": "4.sql",
			"desc": "create customer4 table"
		}
	]	
}

撰寫 powershell 腳本

$sitejson = Get-Content './site.json' | Out-String | ConvertFrom-Json
$sqljson = Get-Content './sql.json' | Out-String | ConvertFrom-Json

$releaseNo = Read-Host 'Please Enter ReleaseNo'
Write-Host $sqljson."$releaseNo"

foreach ($site in $sitejson.servers)
{    
	$n = $site.name
	$s = $site.server
    $d = $site.db
    $u = $site.user
    $p = $site.password
	$switch = $site.switch
	# Write-Host "$s,$d,$u,$p "
		
	if($switch -eq 'on')
	{	
	 Write-Host "Start DB deploy - $n($s)"	 
	foreach ($sql in $sqljson."$releaseNo")
	{    
		$filename=$sql.filename;
		Write-Host "execute $filename"	 
		
		& sqlcmd -S "$s" -d "$d" -U $u -P $p -f 950 -i  "./$filename" 	 	 
	 
	}	
	Write-Host "Finish DB deploy - $n($s)"	
	Write-Host ""
	}
}

pause

如何使用

1.對 RunSql.ps1 右鍵 > 用 powershell 執行
2.依據 sql.json 設定檔,輸入要部署的 Release No

3.SQL腳本執行成功的畫面
補充:SQL腳本執行失敗的畫面