亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 數據庫 > PostgreSQL > 正文

PostgreSQL 創建表分區

2020-03-12 23:55:17
字體:
來源:轉載
供稿:網友
在pg里表分區是通過表繼承來實現的,一般都是建立一個主表,里面是空,然后每個分區都去繼承它。
 
 
創建表分區步驟如下: 
1. 創建主表 
CREATE TABLE users ( uid int not null primary key, name varchar(20)); 
2. 創建分區表(必須繼承上面的主表) 
CREATE TABLE users_0 ( check (uid >= 0 and uid< 100) ) INHERITS (users); 
CREATE TABLE users_1 ( check (uid >= 100)) INHERITS (users); 
3. 在分區表上建立索引,其實這步可以省略的哦 
CREATE INDEX users_0_uidindex on users_0(uid); 
CREATE INDEX users_1_uidindex on users_1(uid); 
4. 創建規則RULE 
CREATE RULE users_insert_0 AS 
ON INSERT TO users WHERE 
(uid >= 0 and uid < 100) 
DO INSTEAD 
INSERT INTO users_0 VALUES (NEW.uid,NEW.name); 
CREATE RULE users_insert_1 AS 
ON INSERT TO users WHERE 
(uid >= 100) 
DO INSTEAD 
INSERT INTO users_1 VALUES (NEW.uid,NEW.name); 
下面就可以測試寫入數據啦: 
postgres=# INSERT INTO users VALUES (100,'smallfish'); 
INSERT 0 0 
postgres=# INSERT INTO users VALUES (20,'aaaaa'); 
INSERT 0 0 
postgres=# select * from users; 
uid | name 
-----+----------- 
20 | aaaaa 
100 | smallfish 
(2 筆資料列) 
postgres=# select * from users_0; 
uid | name 
-----+------- 
20 | aaaaa 
(1 筆資料列) 
postgres=# select * from users_1; 
uid | name 
-----+----------- 
100 | smallfish 
(1 筆資料列) 
到這里表分區已經可以算完了,不過還有個地方需要修改下,先看count查詢把。 
postgres=# EXPLAIN SELECT count(*) FROM users where uid<100; 
QUERY PLAN 
--------------------------------------------------------------------------------------------- 
Aggregate (cost=62.75..62.76 rows=1 width=0) 
-> Append (cost=6.52..60.55 rows=879 width=0) 
-> Bitmap Heap Scan on users (cost=6.52..20.18 rows=293 width=0) 
Recheck Cond: (uid < 100) 
-> Bitmap Index Scan on users_pkey (cost=0.00..6.45 rows=293 width=0) 
Index Cond: (uid < 100) 
-> Bitmap Heap Scan on users_0 users (cost=6.52..20.18 rows=293 width=0) 
Recheck Cond: (uid < 100) 
-> Bitmap Index Scan on users_0_uidindex (cost=0.00..6.45 rows=293 width=0) 
Index Cond: (uid < 100) 
-> Bitmap Heap Scan on users_1 users (cost=6.52..20.18 rows=293 width=0) 
Recheck Cond: (uid < 100) 
-> Bitmap Index Scan on users_1_uidindex (cost=0.00..6.45 rows=293 width=0) 
Index Cond: (uid < 100) 
(14 筆資料列) 
按照本來想法,uid小于100,理論上應該只是查詢users_0表,通過EXPLAIN可以看到其他他掃描了所有分區的表。 
postgres=# SET constraint_exclusion = on; 
SET 
postgres=# EXPLAIN SELECT count(*) FROM users where uid<100; 
QUERY PLAN 
--------------------------------------------------------------------------------------------- 
Aggregate (cost=41.83..41.84 rows=1 width=0) 
-> Append (cost=6.52..40.37 rows=586 width=0) 
-> Bitmap Heap Scan on users (cost=6.52..20.18 rows=293 width=0) 
Recheck Cond: (uid < 100) 
-> Bitmap Index Scan on users_pkey (cost=0.00..6.45 rows=293 width=0) 
Index Cond: (uid < 100) 
-> Bitmap Heap Scan on users_0 users (cost=6.52..20.18 rows=293 width=0) 
Recheck Cond: (uid < 100) 
-> Bitmap Index Scan on users_0_uidindex (cost=0.00..6.45 rows=293 width=0) 
Index Cond: (uid < 100) 
(10 筆資料列) 
到這里整個過程都OK啦!
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
久久国产视频网站| 亚洲精品成人久久电影| 亚洲香蕉成视频在线观看| 国产在线拍揄自揄视频不卡99| 日本欧美精品在线| 欧美精品手机在线| 国产精品免费视频久久久| 欧美精品18videos性欧美| 日韩中文字幕精品| 成人福利在线视频| 欧美日韩另类视频| 国产综合在线观看视频| 国产日韩精品视频| 丰满岳妇乱一区二区三区| 日韩电影第一页| 国产一区二区免费| 黑人极品videos精品欧美裸| 日韩中文字幕在线播放| 国产成人在线精品| 国产成人精品在线| 欧美人成在线视频| 操91在线视频| 日韩毛片在线观看| 亚洲国产99精品国自产| 欧美激情免费看| 欧美日韩国产va另类| 在线观看日韩专区| 欧美性色19p| 亚洲日韩第一页| 日韩精品在线观看视频| 国产精品吴梦梦| 91免费在线视频网站| 2020国产精品视频| 性欧美在线看片a免费观看| 黑人狂躁日本妞一区二区三区| 日韩一区av在线| 操日韩av在线电影| 亚洲欧美日韩视频一区| 久久人人爽人人爽人人片av高清| 成人国内精品久久久久一区| 国产ts人妖一区二区三区| 久久精品久久久久| 日韩在线资源网| 免费av在线一区| 国内自拍欧美激情| 中文字幕亚洲欧美日韩高清| 成人激情视频在线观看| 日本免费一区二区三区视频观看| 亚洲欧美激情在线视频| 国产精品91在线观看| 91精品国产综合久久男男| 欧美限制级电影在线观看| 欧美日韩中文字幕日韩欧美| 综合欧美国产视频二区| 久久天天躁日日躁| 91网站在线免费观看| 国产精品精品久久久久久| 日韩中文字幕在线看| 亚洲第一国产精品| 美女少妇精品视频| 国产精品夜间视频香蕉| 91国内产香蕉| 两个人的视频www国产精品| 欧美大片第1页| 亚洲国产精品专区久久| 国产亚洲一级高清| 久久国产精品久久久久久| 亚洲色图25p| 欧美激情成人在线视频| 亚洲欧洲高清在线| 国产精品久久视频| 97精品国产91久久久久久| 久久视频在线播放| 国产丝袜一区二区| 国产福利视频一区二区| 亚洲精品国产电影| 国产午夜精品美女视频明星a级| 久久视频免费在线播放| 69久久夜色精品国产69乱青草| 久久久精品999| 日韩小视频在线观看| 国产精品久久久999| 亚洲一区www| 国产一区二区免费| 国产精品成人一区| 久青草国产97香蕉在线视频| 亚洲色图狂野欧美| 久久精品美女视频网站| 91九色综合久久| 国产精品99久久99久久久二8| 欧美成人免费一级人片100| 亚洲国产精品99久久| 高清欧美性猛交| 亚洲精品成a人在线观看| 黑人狂躁日本妞一区二区三区| 成人免费视频在线观看超级碰| 欧美国产日韩免费| 国产亚洲精品美女久久久久| 国产精品亚洲自拍| 国产精品欧美激情| 国产99久久精品一区二区| 国产精品一区二区av影院萌芽| 欧美极品少妇xxxxⅹ免费视频| 精品久久久久久久久久久| 欧美成人午夜视频| 久久久成人精品视频| 国产精品久久久久久久久粉嫩av| 国产成人亚洲综合91精品| 日韩av免费在线观看| 久久精品99久久久久久久久| 亚洲人成亚洲人成在线观看| 久久国产精品久久久| 久久精品久久精品亚洲人| 亚洲free性xxxx护士白浆| 亚洲色图综合网| 国产精品专区一| 中文字幕免费国产精品| 国产精品免费一区二区三区都可以| 成人亚洲欧美一区二区三区| 国产精品日韩在线| 97超碰国产精品女人人人爽| 最新国产成人av网站网址麻豆| 久久777国产线看观看精品| 插插插亚洲综合网| 亚洲欧美另类自拍| 中文字幕精品网| 久久久女女女女999久久| 国产美女精品视频免费观看| 国内成人精品视频| 日韩av在线电影网| 色久欧美在线视频观看| 91视频8mav| 18性欧美xxxⅹ性满足| 亚洲精品欧美一区二区三区| 国产成人福利网站| 中文字幕在线观看亚洲| 久久精品国产一区| 亚洲色图国产精品| 国产日本欧美一区二区三区在线| 精品久久久av| 亚洲xxxxx| 亚洲黄色免费三级| 91国内揄拍国内精品对白| 欧美在线一区二区视频| 亚洲免费人成在线视频观看| 在线色欧美三级视频| 欧美午夜宅男影院在线观看| 中文字幕亚洲一区| 亚洲精品一区在线观看香蕉| 国产精品入口夜色视频大尺度| 91国产在线精品| 欧美日韩一区二区免费在线观看| 欧美壮男野外gaytube| 亚洲精品自产拍| 亚洲成色777777女色窝| 久精品免费视频| 色偷偷88888欧美精品久久久| 欧美成人激情图片网| 亚洲激情在线视频| 欧美精品久久久久久久免费观看| 久久免费精品视频| 国产精品专区h在线观看| 欧美激情亚洲综合一区| 国产精品福利在线观看|