postgresql對錶空間的說明很簡單,基於兩點理由:
- 擴充儲存空間,跳出os對檔案系統的大小限制,不斷擴充可以空間
- 讓資料庫管理員針對系統的應用特點....最佳化系統的效能。
postgresql的tablespace就是讓postgresq使用的專用os目錄(路徑)。並沒有什麼神秘的地方。在一個邏輯檔案系統上建立多個資料表空間沒有多少意義,因為你不能控制邏輯檔案系統裡的單個檔案
create tablespace tbl_name location 'os_dir_path_str'; --os_path必須是空的、postgresql帳號有權的目錄。建立資料表空間的使用者必須是superuser,建立完資料表空間之後,可以將資料表空間的create許可權賦給普通使用者使用!
指定資料表空間、預設資料表空間
- 資料表空間的使用對象:表、index、資料庫:在建立這些對象時,可以顯式的指定tablespace tals_name子句指示對象使用的資料表空間;
- 如果不指定,系統會使用當前有效預設資料表空間。
- 類似的,暫存資料表和暫存資料表的index、內部暫存資料表:也有預設的暫存資料表空間。指定暫存資料表空間系統參數時,可以指定多個資料表空間,postgresql會隨機使用它們
- initdb.exe初始化的兩個預設資料表空間pg_global、pg_default
- 資料庫預設的資料表空間pg_default 是用來儲存系統目錄對象、使用者表、使用者表index、和暫存資料表、暫存資料表index、內部暫存資料表的預設空間。他是模板資料庫template0和template1的預設資料表空間
- 資料庫預設的資料表空間pg_global是用來儲存共用系統目錄的預設空間
- 資料庫預設資料表空間可以在create database是通過 tablespace tbs_anme 子句來改變
資料表空間是和單個資料庫無關的,他被所有的資料庫使用。因此,資料表空間只有沒有任何對象使用時,才能drop掉!
postgresql允許 通過符號連結 簡化資料表空間的實施,那在不支援符號連結的os上就無法簡化,只能顯式的建立所需的資料表空間了!