Postgresql:資料表空間

來源:互聯網
上載者:User

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上就無法簡化,只能顯式的建立所需的資料表空間了!

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.