我已经尝试过这里列出的工具,其中一些比其他工具更成功,但没有一个给我可以使用的有效 postgres 语法(tinyint 错误等)
9 回答
有一个mysqldump
选项可以输出 PostgreSQL 代码:
mysqldump --compatible=postgresql ...
但这不太好。
试试这个,它就像魅力一样!
http://www.sqlines.com/online
在 Debian(或 Ubuntu)上安装pgloader :
sudo apt install pgloader
以 postgres 用户登录并创建数据库
sudo su postgres
createdb -O user db_migrated
将数据从mysql数据库传输到postgresql
pgloader mysql://user@localhost/db postgresql:///db_migrated
还检查Dimitri Fontaine 将 pgloader 从 python 重写为 common lisp,以便他可以实现真正的线程。
其他平台安装
要在 Windows 上安装 pgloader,您可以使用适用于 Linux 的 Windows 子系统。
要在 Mac 上安装 pgloader,您可以使用:
brew install --HEAD pgloader
.
我用过py-mysql2pgsql。安装后只需要 yml 格式的简单配置文件(源,目标),例如:
# if a socket is specified we will use that
# if tcp is chosen you can use compression
mysql:
hostname: localhost
port: 3306
socket: /tmp/mysql.sock
username: mysql2psql
password:
database: mysql2psql_test
compress: false
destination:
# if file is given, output goes to file, else postgres
file:
postgres:
hostname: localhost
port: 5432
username: mysql2psql
password:
database: mysql2psql_test
用法:
> py-mysql2pgsql -h
usage: py-mysql2pgsql [-h] [-v] [-f FILE]
Tool for migrating/converting data from mysql to postgresql.
optional arguments:
-h, --help show this help message and exit
-v, --verbose Show progress of data migration.
-f FILE, --file FILE Location of configuration file (default:
mysql2pgsql.yml). If none exists at that path,
one will be created for you.
看看PG Foundry,Postgres 的额外实用程序往往会在那里。我相信您正在寻找的工具确实存在。
此 postgresql 页面上列出了一款付费软件: http ://www.postgresql.org/download/products/1
这是在pgFoundry: http ://pgfoundry.org/projects/mysql2pgsql/
此页面列出了语法差异,但我还没有找到一个简单的工作查询转换器。使用ORM包而不是原始 SQL 可以防止这些问题。
我目前正在为遗留代码库开发一个转换器:
function mysql2pgsql($mysql){
return preg_replace("/limit (\d+), *(\d+)/i", "limit $1 offset $2", preg_replace("/as '([^']+)'/i", 'as "$1"', $mysql)); // Note: limit needs order
}
对于CREATE
语句,SQLines会在线转换大部分语句。不过,之后我仍然必须编辑 mysqldump:
"mediumtext" -> "text", "^LOCK.*" -> "", "^UNLOCK.*" -> "", "`" -> '"', "'" -> "''" in 'data', "0000-00-00" -> "2000-01-01", deduplicate constraint names, " CHARACTER SET utf8 " -> " ".
"int(10)" -> "int" was missed in the last table, so pass that part of the mysqldump through http://www.sqlines.com/online again.
您很可能永远不会获得可以为您完成所有工作的此类任务的工具。准备好自己做一些重构工作。