Mark Ku's Blog
首頁 關於我
透過 Powershell 部署 SQL 腳本到多個網站的資料庫
PowerShell
透過 Powershell 部署 SQL 腳本到多個網站的資料庫
Mark Ku
Mark Ku
June 04, 2021
1 min

問題

有一套系統,卻克隆 ( 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腳本執行失敗的畫面


Tags

Mark Ku

Mark Ku

Software Developer

10年以上豐富網站開發經驗,開發過各種網站,電子商務、平台網站、直播系統、POS系統、SEO 優化、金流串接、AI 串接,Infra 出身,帶過幾次團隊,也加入過大團隊一起開發。

Expertise

前端(React)
後端(C#)
網路管理
DevOps
溝通
領導

Social Media

facebook github website

Related Posts

Reduce the risk of manual deployment using powershell and beyondcompare
Reduce the risk of manual deployment using powershell and beyondcompare
June 27, 2023
1 min

Quick Links

關於我

Social Media