文档章节

多平台向Postgresql 迁移

从前
 从前
发布于 2013/01/30 20:31
字数 590
阅读 1726
收藏 9

最近有个工作要把 一个SqlServer 迁移到 Postgresql 平台上,上网搜了搜,EnterpriseDB在这块做了很多工作,

EnterpriseDB 的 Postgres Plus Advanced Server管理工具中有一个 mogiration toolkit工具。

这里安装的是9.2版本。安装后在 bin 目录下有个edb-migrationtoolkit.jar,这是这个工具的主要程序,通过java 启用jar包进行迁移。其中涉及到三块:

1.bin目录下 edb-migrationtoolkit.jar 迁移主程序

2.bin目录下runMTK.bat 迁移命令脚本,linux下是runMTK.sh,内容如下,这里有些改动

@echo off
@REM ----------------------------------------------------------------------------
@REM --
@REM -- Copyright (c) 2004-2012 - EnterpriseDB Corporation.  All Rights Reserved.
@REM --
@REM ----------------------------------------------------------------------------

"D:\dev\Java\jre7\bin\java.exe" -Dprop=..\etc\toolkit.properties -jar edb-migrationtoolkit.jar -sourcedbtype sqlserver -targetdbtype postgresql -targetSchema public dbo %*
说明 : 
-sourcedbtype sqlserver -targetdbtype postgresql -targetSchema public dbo

上面的配置指定了 源数据库类型,和目标数据库类型。 -targetSchema 指定数据库架构,public表示 postgresql 数据库架构,dbo表示 sql server的数据库架构

更多的配置和迁移参数 使用命令 runMTK -help。

3.etc目录下toolkit.properties文件,迁移时源数据库和目标数据库的连接配置,java的连接配置

安装的时候默认的是迁移 oracle到postgresql 这里需要改下。同时由于edb-migrationtoolkit.jar程序中采用的是jtds的 sql server驱动,所以更改如下

SRC_DB_URL=jdbc:jtds:sqlserver://localhost:1433;databasename=test
SRC_DB_USER=sa
SRC_DB_PASSWORD=123456


TARGET_DB_URL=jdbc:postgresql://localhost:5432/test
TARGET_DB_USER=postgres
TARGET_DB_PASSWORD=123456


需要两个额外的 东西,SqlServer 的 jdbc驱动 和postgresql 的jdbc驱动。

http://www.sql-workbench.net/manual/jdbc-setup.html 这个页面查看所有数据库的java 驱动,比较全面。

:在安装Postgres Plus Advanced Server 的mogiration toolkit模块的时候会自动安装jre 在根目录下,但这个版本比较低,还是java 5的。所以如果使用这个jre 的java启动 迁移的时候下载的对应数据jdbc驱动必须支持java5当然。可以采用自己安装的高版本jre,同时下载驱动放在jre/lib/ext 目录下。

这个工具还是比较好用的,比较智能化,无需其他的操作。当然在迁移的时候会遇到一些小问题,比如各个数据库中专有的东西。例如 sql server 会把和 关键字 冲突的列名 加上 [] 。迁移的时候就出错了

同时这个工具可以迁移多个平台。如下:


© 著作权归作者所有

从前

从前

粉丝 36
博文 75
码字总数 29813
作品 1
成都
程序员
私信 提问
Toad 数据建模工具发布 4.0 版本

Toad Data Modeler 4.0 发布了,这是一个多平台的数据建模和设计工具,该版本增加了对 PostgreSQL 9.0 的支持 主要特性: - Entity Relationship Diagrams - Generation of SQL code - Reve...

红薯
2011/08/05
1K
0
PostgreSQL 大版本升级方法之一 - 不落地并行导出导入

标签 PostgreSQL , 大版本升级 , rdsdbsync , pgdump , pg_restore 背景 尽量快的大版本升级的方法。 一、9.4以下版本,使用pgdump并行导出,pg_restore并行导入,迁移 (导出使用源版本pgdum...

德哥
04/14
0
0
PostgreSQL 8.4.3 Final / 9.0 Alpha 4

PostgreSQL 是一种对象-关系型数据库管理系统(ORDBMS),也是目前功能最强大、特性最丰富和最复杂的自由软件数据库系统.它起源于伯克利 (BSD)的数据库研 究计划,目前是最重要的开源数据库产品开...

红薯
2010/03/15
213
0
PostgreSQL 用 CTE语法 + 继承 实现拆分大表

背景 业务设计初期可能不会考虑到表将来会有多大,或者由于数据日积月累,单表会变得越来越大。 后面在考虑分区的话,应该怎么将单表切换成分区表呢? 这里可以用到PostgreSQL的CTE语法,以及...

流浪的猫666
2018/07/15
0
0
线下PG迁移到阿里云RDS PG - 兼容性、性能评估、迁移

标签 PostgreSQL , 迁移 , 阿里云RDS PG 背景 用户如果需要将线下的PG数据库迁移到阿里云RDS PG,应该评估哪些东西,如何迁移? 1 规格、性能评估 主要评估线下PG实例所在主机的性能指标 1、...

德哥
2018/09/15
0
0

没有更多内容

加载失败,请刷新页面

加载更多

win mysql 安装笔记

官方下载zip的mysql包,解压即可 目录: D:\mysql_file\mysql-5.7.26-winx64 在该目录下新建一个文件夹data (如果操作过程中失败,要把data中的所有文件删掉) 新建一个文件,命名为my.ini,内容...

_大侠__
9分钟前
1
0
第八届“中国软件杯”初赛评审完美收官,课工场赛题备受关注

日前,由工业和信息部、教育部、江苏省人民政府共同创办第八届“中国软件杯”大学生软件设计大赛初赛评审历时两天,于 6 月 23 日圆满结束。由中国科学院软件研究所专家、各高校软件学院相关...

IFTNews
22分钟前
0
0
日期居然用字符串保存?我笑了

微信公众号「后端进阶」,专注后端技术分享:Java、Golang、WEB框架、分布式中间件、服务治理等等。 老司机倾囊相授,带你一路进阶,来不及解释了快上车! 我发现数据库有些日期居然用字符串...

后端进阶
24分钟前
2
0
c 基础教程四:c 输入输出(二)

在C语言中,有三个函数可以用来在显示器上输出数据,它们分别是: puts():只能输出字符串,并且输出结束后会自动换行 putchar():只能输出单个字符 printf():可以输出各种类型的数据 prin...

故城以南丶思念不安
26分钟前
1
0
SSO简单实现与理解

SSO英文全称Single Sign On,单点登录。SSO是在多个应用系统中,用户只需要登录一次就可以访问所有相互信任的应用系统。它包括可以将这次主要的登录映射到其他应用中用于同一个用户的登录的机...

辣条QAQ
27分钟前
1
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部