日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 运维知识 > 数据库 >内容正文

数据库

MySQL数据库迁移到PostgreSQL

發(fā)布時間:2023/12/15 数据库 33 豆豆
生活随笔 收集整理的這篇文章主要介紹了 MySQL数据库迁移到PostgreSQL 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

為什么80%的碼農(nóng)都做不了架構(gòu)師?>>> ??

查了不少資料,也嘗試了一些,最后采用的辦法如下:

1. 導(dǎo)出mysql表定義(無數(shù)據(jù))
mysqldump --no-data [dbname] >dbdef.sql

2. 使用mysql2postgres把腳本轉(zhuǎn)換為pgsql

3. 上面生成的腳本還不一定很完美,可以嘗試導(dǎo)入pgsql,調(diào)試錯誤并手動修改之。我遇到的問題就只有一個,mysql列定義中的zerofill需要手工 去掉。一些unsinged定義會生成constraint,如果不需要可以去掉。另外,trigger都有問題,只能后面手工重建

4. 導(dǎo)出mysql數(shù)據(jù):
mysqldump -v -nt --complete-insert=TRUE --compact --no-create-info --skip-quote-names [dbname] >dbdata.sql
老一些版本的pgsql如果不支持批量插入的話還需要加上--extended-insert=FALSE,這個性能損失巨大。

5. 轉(zhuǎn)義符
mysql默認(rèn)字符串里的'\'是轉(zhuǎn)義符,而pgsql默認(rèn)不是,修改postgresql.conf:
backslash_quote = on
escape_string_warning = off
standard_conforming_strings = off
數(shù)據(jù)導(dǎo)入完成后可以改回默認(rèn)值。

5. pgsql里導(dǎo)入表定義和數(shù)據(jù)
psql -d [dbname] <dbdef.sql
psql -d [dbname] <dbdata.sql

6. 重建trigger

7. 自增主鍵(字段)的處理
由于導(dǎo)入數(shù)據(jù)時此字段都是有值的,所以pgsql里面seq并不會增加,可以用如下語句設(shè)置自增列的當(dāng)前值:
SELECT setval('sample_id_seq',max(id)) from sample;

最后,如果數(shù)據(jù)量大,導(dǎo)入時考慮性能可以先把主鍵、索引、約束都去掉,導(dǎo)入完成后再加上。另外,psql客戶端從管道導(dǎo)入數(shù)據(jù)似乎不夠快,可以用tcp方式psql -h localhost ,還有一些為大數(shù)據(jù)量導(dǎo)入優(yōu)化的參數(shù),大概列一下:

autovacuum = off

wal_level = minimal

archive_mode = off

full_page_writes = off

fsync = off

checkpoint_segments = 50??
checkpoint_timeout = 1h

maintenance_work_mem視內(nèi)存情況盡量大點

轉(zhuǎn)載于:https://my.oschina.net/ruralhunter/blog/48745

總結(jié)

以上是生活随笔為你收集整理的MySQL数据库迁移到PostgreSQL的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。