在 WSL Ubuntu 上从零到数据迁移:通过 pgloader 将 SQL Server 转 PostgreSQL 实战笔记

将 sqlserver 转 postgresql ,用 pgloader 的笔记

1. 环境初始化(WSL2 Ubuntu 22.04)

bash 复制代码
# 换国内源(可选)
sudo sed -i 's@http://.*.ubuntu.com@https://mirrors.tuna.tsinghua.edu.cn@g' /etc/apt/sources.list
sudo apt update && sudo apt upgrade -y

# 装依赖
sudo apt install -y freetds-bin freetds-dev libsqlite3-dev gawk make g++ curl git

2. 安装 pgloader

bash 复制代码
# 最快方案
sudo apt install -y pgloader
pgloader --version          # ≥3.6.2 即可

3. 验证 FreeTDS 能连 SQL Server

bash 复制代码
# 脱敏变量,自行替换
export MSSQL_HOST='<SQL_SERVER_IP>'
export MSSQL_PORT='1433'
export MSSQL_USER='<USER>'
export MSSQL_PASS='<PASSWORD>'
export MSSQL_DB='<DATABASE>'

tsql -H $MSSQL_HOST -p $MSSQL_PORT -U $MSSQL_USER -P $MSSQL_PASS -D $MSSQL_DB

看到 1> 表示连通,输入 exit 退出。


4. 迁移脚本(脱敏版)

文件:migrate.load

lisp 复制代码
LOAD DATABASE
     FROM mssql://<USER>:<PASSWORD>@<SQL_SERVER_IP>:1433/<DATABASE>
     INTO postgresql://<PG_USER>:<PG_PASSWORD>@<PG_HOST>:5432/<PG_DATABASE>
WITH include drop, create tables, create indexes, reset sequences
ALTER SCHEMA 'dbo' RENAME TO 'central';

5. 跑!

bash 复制代码
pgloader migrate.load

进度实时刷,出错看 /tmp/pgloader/*.log


6. 翻车急救表

报错 一键排查
unknown reason `ldd $(which pgloader)
Login failed 检查混合模式 & 密码
时间字段全 NULL CAST type datetime to timestamp
大表超时 WITH batch rows = 10000, prefetch rows = 10000

7. 迁移后三板斧

sql 复制代码
VACUUM ANALYZE central.*;
GRANT USAGE ON SCHEMA central TO <APP_ROLE>;
GRANT SELECT,INSERT,UPDATE,DELETE ON ALL TABLES IN SCHEMA central TO <APP_ROLE>;

8. 收尾

WSL 里一条命令即可把 SQL Server 整个 schema 搬进 PostgreSQL,记得

"先让 tsql 通,再让 pgloader 飞"。

相关推荐
syc789012316 分钟前
中文语境下AI编码工具实战对比:从迭代体验看日常开发选择
linux·人工智能·ubuntu
袁小皮皮不皮2 小时前
1.HCIP BFD 学习笔记(优化版)
服务器·网络·笔记·网络协议·学习·智能路由器·ip
vsropy3 小时前
Ubuntu网络图标消失问题/有网络问号
linux·运维·ubuntu
coderwu3 小时前
Ubuntu 24.04 终端输入 openclaw config 提示未找到命令解决办法
linux·运维·ubuntu
hhcgchpspk6 小时前
汇编语言传递数据和地址的误区
汇编·笔记·nasm·masm
智者知已应修善业6 小时前
【51单片机2个外部中断显示中断历时,初始化8左移3位共阳数码管】2024-6-6
c++·经验分享·笔记·算法·51单片机
tq10868 小时前
OperationSequence DSL 2.1 语法规范
笔记
智者知已应修善业9 小时前
【用74LS151的实现(16序列信号发生器)】2024-6-1
驱动开发·经验分享·笔记·硬件架构·硬件工程
是上好佳佳佳呀10 小时前
【LangChain|Day04】RAG 全流程基础笔记:Document 、 Loader 和 Splitter
笔记·langchain·rag
俊男无期10 小时前
【无标题】
笔记·其他