介紹如何在 Linux 系統下以指令的方式進行 PostgreSQL 資料庫的備份與恢復。
備份 PostgreSQL 資料庫
若要以 myaccount
這個普通 PostgreSQL 資料庫使用者帳號透過 pg_dump
指令來備份整個 mydb
資料庫,可以執行:
# 備份 PostgreSQL 資料庫 pg_dump -h localhost -U myaccount -Fc mydb > mydb.dump
此處的 -Fc
參數是讓 pg_dump
以 custom
格式輸出,此格式必須搭配 pg_restore
來恢復使用。如果不指定 -Fc
參數,則 pg_dump
預設會以 SQL 文字指令稿的格式輸出。
若要以系統管理者的權限來備份 mydb
資料庫,則可執行:
# 備份 PostgreSQL 資料庫 sudo -u postgres pg_dump -Fc mydb > mydb.dump
恢復 PostgreSQL 資料庫
若要以 myaccount
這個普通 PostgreSQL 資料庫使用者帳號,透過 pg_restore
指令來將 mydb.dump
這個備份檔案恢復至 newdb
這個資料庫中,可以執行:
# 恢復 PostgreSQL 資料庫 pg_restore -h localhost -U myaccount -d newdb mydb.dump
若要以系統管理者的權限來將 mydb.dump
這個備份檔案恢復至 newdb
這個資料庫中,可以執行:
# 恢復 PostgreSQL 資料庫 sudo -u postgres pg_restore -d newdb mydb.dump
備份 PostgreSQL 資料表
若只要備份特定的 PostgreSQL 資料表(其餘不備份),可以在執行 pg_dump
時以 --table
指定要進行備份的資料表名稱:
# 備份 PostgreSQL 資料表 pg_dump -Fc -h localhost -U myaccount \ --table=mytable1 \ --table=mytable2 \ mydb > mytable.dump
恢復 PostgreSQL 資料表
如果在恢復資料表時,只要恢復特定的幾張資料表(其餘不恢復),可以使用 --table
參數指定要恢復的資料表名稱:
# 恢復 PostgreSQL 資料表 pg_restore --clean -h localhost -U myaccount -d newdb \ --table=mytable1 \ --table=mytable2 \ mytable.dump
只備份 PostgreSQL 資料庫 Schema 定義
若只需要備份資料庫中各物件的定義,可以加上 --schema-only
參數:
# 備份 PostgreSQL 資料庫 Schema 定義 pg_dump -h localhost -U myaccount --schema-only mydb > mydb_schema.sql
通常資料庫的 schema 定義都非常小,所以這裡直接以預設的文字格式輸出,方便修改與使用。
只備份 PostgreSQL 資料庫資料
若只要備份資料庫的資料,不含資料庫 schema 定義,則可加上 --data-only
參數:
# 備份 PostgreSQL 資料庫資料 pg_dump -h localhost -U myaccount -Fc --data-only mydb > mydb_data.dump
從 SQL 文字指令稿恢復
如果備份資料庫時是以 SQL 文字指令稿的格式輸出,則恢復時就要搭配 psql
指令:
# 從 SQL 指令稿恢復資料庫 psql -h localhost -U myaccount -d newdb -f mydb.sql
參考資料:5XRUBY