PostGresql最全分割槽操作

2021-10-02 13:18:32 字數 3881 閱讀 4557

分割槽表意思是將乙個大表在物理上分割成幾塊,gpdb中的分割槽表和postgresql中實現原理一樣,都是用過錶繼承、約束來實現。但是與postgresql也有所不同,在postgresql中,乙個父表,多個子表來實現分割槽表,需要手動向子表插入資料,如果向父表插入資料,則直接會被插入到父表中,在gpdb中,可以直接想父表插入資料,便可以根據約束直接自動向對應的子表插入資料,當分割槽子表不存在時,插入失敗

根據分割槽欄位的值範圍區間來分割槽,每乙個分割槽就是乙個子表

eg:

create table test_partition_range

(

id int,

name varchar(64),

fdate varchar(64)

) distributed by (id)

partition by range(fdate)

(

partition p1 start ('2017-01-01') inclusive end ('2017-01-31') exclusive,

partition p2 start ('2017-02-01') inclusive end ('2017-02-29') exclusive,

default partition default_p

);

inclusive :指定包含,例如上面的 start ('2017-01-01') inclusive 則是包含'2017-01-01'

exclusive : 指定不包含, 例如上面的 end ('2017-01-31') exclusive 則是不包含'2017-01-31'

根據選定的範圍,跨越基數,快速分割槽每乙個子表

eg:

create table test_partition_every_1

(

id int,

name varchar(64),

fdate date

)

distributed by (id)

partition by range (fdate)

(

partition pn_ start ('2017-01-01'::date) end ('2017-12-31'::date) every ('1 day'::interval),

default partition default_p

);

every:指定跨越基數

根據值的分組,相同的資料歸類到一組,也就乙個分割槽中

eg:

create table test_partition_list

(

id int,

name varchar(64),

fdate varchar(10)

)

distributed by (id)

partition by list (fdate)

(

partition p1 values ('2017-01-01', '2017-01-02'),

partition p2 values ('2017-01-03'),

default partition pd

);

切割普通分割槽:

將分割槽p2 在 '2017-02-20' 左右切分成兩塊

alter table test_partition_range split partition p2 at ('2017-02-20') into (partition p2, partition p3);

切割預設分割槽:

alter table test_partition_range split default partition start ('2017-03-01') end ('2017-03-31') into (partition p4, default partition);

如果存在default partition,則不能add分割槽,只能split default partition

alter table test_partition_range_1 add partition p2 start ('2017-02-01') end ('2017-02-31');
徹底刪除對應的分割槽表

alter table test_partition_range_1 drop partition p2;
清空分割槽表資料,相當於刪除分割槽,然後再新建乙個

alter table test_partition_range_1 truncate partition p1;
在gpdb中,分割槽是可以巢狀增加的,分割槽下面可以有子分割槽

create table test_partition_range_2

(

id int,

name varchar(64),

fdate varchar(10)

)

distributed by (id)

partition by range(fdate)

subpartition by list(name)

subpartition template

(

subpartition c1 values ('xiaoxiao'),

subpartition c2 values ('xiaohua')

)

(

partition p1 start ('2017-01-01') end ('2017-01-31')

)

上面的分割槽中,p1會再分兩個c1/c2子分割槽

alter table test_partition_range_2 alter partition p1 truncate partition c2;
alter table test_partition_range_2 alter partition p1 drop partition c2;

postgresql表分割槽

pg的表分割槽實際就是所說的分表,pg的表分割槽的是採用繼承表的方式。表繼承所有父表的檢查與約束都會被子表繼承,主外來鍵關係不會。乙個子表可以繼承多個父表,修改父表的表結構時,大多數情況下也會修改子表的結構定義。分割槽表就是把邏輯上的乙個大表分割成物理上的幾個小塊。好處 1 delete資料更快,只...

mysql分割槽實操

分成2步 2.將原表資料插入新錶 insert into 目標表 select from 表 create table met shopv2 order copy1 id int 11 not null auto increment,orderid varchar 20 character set ...

postgresql中的資料分割槽

目錄 環境文件用途 詳細資訊 環境系統平台 n a 版本 10.0,9.6,8.4 文件用途 本文旨在用於指導資料分割槽和資料分割槽方法。詳細資訊 什麼是資料分割槽?對於具有極大表的資料庫,分割槽對於資料庫設計人員而言是一種慣用的技巧,可以提高資料庫效能並使維護更加容易。postgresql資料庫中...