Categories: 資料庫

PostgreSQL 資料庫備份、恢復教學與範例

介紹如何在 Linux 系統下以指令的方式進行 PostgreSQL 資料庫的備份與恢復。

備份 PostgreSQL 資料庫

若要以 myaccount 這個普通 PostgreSQL 資料庫使用者帳號透過 pg_dump 指令來備份整個 mydb 資料庫,可以執行:

# 備份 PostgreSQL 資料庫
pg_dump -h localhost -U myaccount -Fc mydb > mydb.dump

此處的 -Fc 參數是讓 pg_dumpcustom 格式輸出,此格式必須搭配 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

Share
Published by
Office Guide
Tags: PostgreSQL

Recent Posts

Python 使用 PyAutoGUI 自動操作滑鼠與鍵盤

本篇介紹如何在 Python ...

1 年 ago

Ubuntu Linux 以 WireGuard 架設 VPN 伺服器教學與範例

本篇介紹如何在 Ubuntu ...

1 年 ago

Linux 網路設定 ip 指令用法教學與範例

本篇介紹如何在 Linux 系...

1 年 ago

Linux 以 Cryptsetup、LUKS 加密 USB 隨身碟教學與範例

介紹如何在 Linux 系統中...

1 年 ago