中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

sql腳本與pg_restore命令怎么在postgreSQL中運行

發布時間:2021-01-06 15:22:14 來源:億速云 閱讀:340 作者:Leah 欄目:開發技術

sql腳本與pg_restore命令怎么在postgreSQL中運行?很多新手對此不是很清楚,為了幫助大家解決這個難題,下面小編將為大家詳細講解,有這方面需求的人可以來學習下,希望你能有所收獲。

postgreSQL運行sql腳本文件:

psql -d dbname -U username -f (腳本所在位置).sql

postgerSQL的pg_restore命令

用法:

pg_restore [選項]… [文件名]

一般選項:

-d, --dbname=名字 連接數據庫名字
-f, --file=文件名 輸出文件名
-F, --format=c|d|t 備份文件格式(應該自動進行)
-l, --list 打印歸檔文件的 TOC 概述
-v, --verbose 詳細模式
-V, --version 輸出版本信息, 然后退出
-?, --help 顯示此幫助, 然后退出

恢復控制選項:

-a, --data-only 只恢復數據, 不包括模式
-c, --clean 在重新創建之前,先清除(刪除)數據庫對象
-C, --create 創建目標數據庫
-e, --exit-on-error 發生錯誤退出, 默認為繼續
-I, --index=NAME 恢復指定名稱的索引
-j, --jobs=NUM 執行多個并行任務進行恢復工作
-L, --use-list=FILENAME 從這個文件中使用指定的內容表排序

輸出

-n, --schema=NAME 在這個模式中只恢復對象
-N, --exclude-schema=NAME 不恢復此模式中的對象
-O, --no-owner 不恢復對象所屬者
-P, --function=NAME(args) 恢復指定名字的函數
-s, --schema-only 只恢復模式, 不包括數據
-S, --superuser=NAME 使用指定的超級用戶來禁用觸發器
-t, --table=NAME 恢復命名關系(表、視圖等)
-T, --trigger=NAME 恢復指定名字的觸發器
-x, --no-privileges 跳過處理權限的恢復 (grant/revoke)
-1, --single-transaction 作為單個事務恢復
–disable-triggers 在只恢復數據的過程中禁用觸發器
–enable-row-security 啟用行安全性
–if-exists 當刪除對象時使用IF EXISTS
–no-comments 不恢復注釋
–no-data-for-failed-tables 對那些無法創建的表不進行

數據恢復

–no-publications 不恢復發行
–no-security-labels 不恢復安全標簽信息
–no-subscriptions 不恢復訂閱
–no-tablespaces 不恢復表空間的分配信息
–section=SECTION 恢復命名節 (數據前、數據及數據后)
–strict-names 要求每個表和(或)schema包括模式以匹配至少一個實體
–use-set-session-authorization
使用 SESSION AUTHORIZATION 命令代替
ALTER OWNER 命令來設置所有權

聯接選項:

-h, --host=主機名 數據庫服務器的主機名或套接字目錄
-p, --port=端口號 數據庫服務器的端口號
-U, --username=名字 以指定的數據庫用戶聯接
-w, --no-password 永遠不提示輸入口令
-W, --password 強制口令提示 (自動)
–role=ROLENAME 在恢復前執行SET ROLE操作

選項 -I, -n, -N, -P, -t, -T, 以及 --section 可以組合使用和指定

多次用于選擇多個對象.

希望不要和我一樣犯這個低級錯誤

順便記錄一下查看server和client的encoding以及修改

找到postgresql.conf文件,修改參數lc_messages的值為UTF8

重啟PostgreSQL的服務。

----查看服務端字符集:

test=> show server_encoding;

—查看客戶端字符集:

test=> show client_encoding;

補充:pg_restore及psql恢復數據的用法

一、使用psql恢復SQL文本格式的數據備份(即一個包含SQL腳本的文本文件)

恢復一個SQL備份文件并忽略過程中可能發生的所有錯誤:

psql -U postgres -f myglobals.sql

恢復一個SQL備份文件,如遇任何錯誤則立即停止恢復:

psql -U postgres --set ON_ERROR_STOP=ON -f myglobals.sql

將SQL文本中的數據恢復到某個指定的database:

psql -U postgres -d mydb -f select_objects.sql

二、使用pg_restore進行恢復

功能:

(1)支持并行恢復,使用-j選項可以控制并行恢復的線程數。多個恢復線程可以并行處理,每個線程處理一張表。該模式可以顯著提高恢復速度。

(2)可以使用pg_restore掃描備份文件來生成一張備份內容列表,通過該列表可以確認備份紅包含了哪些內容。還可以通過編輯該內容列表來控制恢復哪些內容。

(3)pg_dump支持選擇性地僅備份部分對象以節省備份時間,類似的,pg_restore也支持選擇性的僅恢復部分對象,不管備份文件本身是全庫備份還是部分對象的備份都沒有問題。

(4)pg_restore的大部分功能是向后兼容的,即支持將老版本PostgreSQL生產的備份數據恢復到新版本的PostgreSQL中。

在使用pg_restore執行恢復動作之前,請先創建目標數據庫:

create database mydb;

然后執行恢復:

pg_restore --dbname=mydb --jobs=4 --verbose mydb.backup

如果備份和恢復時使用的database同名,則可以通過加--create選項省去單獨建庫的過程,如下:

pg_restore --dbname=postgres --create --jobs=4 --verbose mydb.backup

注:如果指定了--create選項,那么恢復出來的數據庫名就會默認采用備份時的數據庫名,不允許改名。如果還同時指定了--dbname選項,那么此時連接的數據庫名一定不能是待恢復的數據庫名,因為要恢復數據庫之前必然要建數據庫,而

要建數據庫之前必然要先連到某個已存在的數據庫,--dbname選項指定的就是建立被恢復的數據庫之前先連到哪個數據庫,所以必然不能與待恢復的數據庫同名,我們一般指定先連到postgres數據庫。

9.2版或更新版本的pg_restore支持--section選項,加上該選項后可以實現僅恢復表結構而不恢復表數據。具體做法是先創建目標恢復數據庫:

create database mydb2;

然后使用pg_restore:

pg_restore --dbname=mydb2 --section=pre-data --jobs=4 mydb.backup

看完上述內容是否對您有幫助呢?如果還想對相關知識有進一步的了解或閱讀更多相關文章,請關注億速云行業資訊頻道,感謝您對億速云的支持。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

巴南区| 台北县| 东乌珠穆沁旗| 贵南县| 格尔木市| 鄂托克前旗| 海晏县| 靖远县| 鹤壁市| 闸北区| 太谷县| 弥勒县| 凤台县| 黄骅市| 岢岚县| 内黄县| 彭州市| 卓尼县| 广平县| 闽侯县| 福州市| 班戈县| 门源| 济南市| 彝良县| 刚察县| 镇坪县| 温宿县| 保山市| 上杭县| 磐安县| 托克逊县| 渝北区| 滁州市| 双鸭山市| 运城市| 崇左市| 五寨县| 石嘴山市| 晋江市| 都匀市|