前言
以下筆者將介紹如何將 Microsoft SQL Server Database 資料轉到 PostgreSQL Database。
環境 : Windows Server 2019, Microsoft SQL Server 2019, PostgreSQL V.13
使用的工具則是 SQL Server Management Studio (SSMS)
環境準備
- 請先安裝好 SQL Server 及 PostgreSQL
先手動建立測試的 DB (ms2postgre1) ,再執行以下的 SQL ,建立 Tables 及 View ,如下,
1 | USE [ms2postgre1] |
也在 PostgreSQL 建立一個 Database 名為 ms2postgre1。
匯出資料
安裝 ODBC Driver
最簡單的方式就是透 SSMS 將資料透過 ODBC 匯出到 PostgreSQL ,
所以要先安裝 PostgreSQL ODBC driver (psqlODBC)。
因為是 SSMS 工具要使用的,所以請安裝 32bit 版本(psqlodbc_13_00_0000-x86.zip)。
data:image/s3,"s3://crabby-images/54746/54746d7db4c88592e7752b835b165a7fc76b2b39" alt="Install PostgreODBC"
data:image/s3,"s3://crabby-images/38817/3881729083cddc178fae06e8d69711b9cb43afdb" alt="Install PostgreODBC-Path"
安裝完成後,就可以開啟 ODBC Data Sources (32bit),
然後在 使用者資料來源名稱 的Tab 按下 新增的 Button,
就可以發現有了 PostgreSQL ANSI 及 PostgreSQL Unicode 的驅動程式。
data:image/s3,"s3://crabby-images/92cc5/92cc5cf62bd1b589cd0e06f8a09e207c606a1fcc" alt="PostgreSQL UNICODE"
而連到 PostgreSQL 的 odbc 連線字串為
1 |
|
MSSQL => PostgreSQL ODBC Driver => PostgreSQL
Driver 好了後,在 SSMS ms2postgre1 DB 上按右鍵,工作->匯出資料(X)
data:image/s3,"s3://crabby-images/4a431/4a431c6dc9459326607f09d7f4d6943e0759e897" alt="匯出資料(X)"
來源 就選取 SQL Server Native Client 11.0 然後設定 ms2postgre1 這個資料庫 ,
data:image/s3,"s3://crabby-images/41bcf/41bcf85826f77639e32db9060dc8d8dd79cb36bb" alt="來源"
目的地 就選取 .NET Framework Data Provider for Odbc 然後輸入 PostgreSQL ODBC 的連線字串。
data:image/s3,"s3://crabby-images/c17fb/c17fb1240d60061bf280ad20847f9d110e449be4" alt="目的地"
再來就選取要轉的資料表,
data:image/s3,"s3://crabby-images/c930e/c930ea619e9e6fc8e8efb68187e030dddbb4f7a9" alt="指定資料表"
我們先試轉 Table1 試試看,
data:image/s3,"s3://crabby-images/28922/2892202615783a88e832ac8320e21ecb24d85eee" alt="Table1"
再按下 編輯對應(E) ,像 char 可以調整成 varchar , money 則改成 numeric。
data:image/s3,"s3://crabby-images/404bf/404bf8e170e971508d8ff143fb9a66e61c83b794" alt="資料行對應"
如果原本已有 Table 存在,就勾選 卸除並重新建立目的地資料表 這個選項
最後就按下一步到最後。
data:image/s3,"s3://crabby-images/d6bdc/d6bdcafff8e44edb40a0d2b976b7a234eaec05ed" alt="資料行對應"
data:image/s3,"s3://crabby-images/fe116/fe11656306889237b9eecedb695ee9f71ef9f8c6" alt="資料行對應"
匯出完成後,就可以到 PostgreSQL 查看資料是否正確!
data:image/s3,"s3://crabby-images/6618e/6618e9898133c2a511bf0c1a0cb2548f1762160c" alt="查看匯出的資料"
參考資料
Connect to a PostgreSQL Data Source (SQL Server Import and Export Wizard)
PostgreSQL ODBC driver (psqlODBC)