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

首頁 > 數據庫 > PostgreSQL > 正文

PostgreSQL之分區表(partitioning)

2020-01-31 15:21:46
字體:
來源:轉載
供稿:網友

PostgreSQL有一項非常有用的功能,分區表,或者partitioning。當某個TABLE的記錄非常的多,千萬甚至更多的時候,我們其實需要將他分割成子表。一個龐大的TABLE,就像水果倉庫雜亂無章地堆放著無數的蘋果桃子和桔子,查找不方便,性能降低,比較合理的做法是將倉庫分成三個子區域,分表放蘋果桃子和桔子。一張大表就變成了三個小表的集合。

通過合理的設計,可以將選擇一定的規則,將大表切分多個不重不漏的子表,這就是傳說中的partitioning。比如,我們可以按時間切分,每天一張子表,比如我們可以按照某其他字段分割,總之了就是化整為零,提高查詢的效能。

怎么實現這個分區表的功能呢?
   1 建立大表。
   2 創建分區繼承
   3 定義Rule或者Trigger?

下面根據一個簡單的例子,描述這個過程。我們將學生按照低于60分和不低于60分切分成兩張子表。

   1 建立大表   

CREATE TABLE student (student_id bigserial, name varchar(32), score smallint)

   2 創建分區繼承。

CREATE TABLE student_qualified (CHECK (score >= 60 )) INHERITS (student) ;CREATE TABLE student_nqualified (CHECK (score < 60)) INHERITS (student) ;

創建了兩個分區表,student_qualified和student_nqualified,繼承了大表student的一切字段,同時設定了約束,即CHECK條件。

3 定義Rule或者Trigger。

   雖然我們定義了CHECK條件,但是往student插入數據時,PostgreSQL并不能根據score是否低于60插入的正確的子表,原因是,你并沒有定義這種規則,來告訴數據這么做。我們需要定義Rule或者Trigger,將數據插入到正確的分區表。
   先看下Rule的定義:

CREATE OR REPLACE RULE insert_student_qualified AS ON INSERT TO student     WHERE score >= 60    DO INSTEAD    INSERT INTO student_qualified VALUES(NEW.*);CREATE OR REPLACE RULE insert_student_nqualified AS ON INSERT TO student     WHERE score < 60    DO INSTEAD    INSERT INTO student_nqualified VALUES(NEW.*);

這兩個Rule告訴了PostgreSQL,當往總表插數據的時候,如果是score< 60,則插入student_nqualified,如果score>=60,則插入student_qualified.注意了,這個分割一定要不重不漏,如果我們不小心將>=60條件的“=”丟掉,等于60分的記錄將會錄入大表student,不在任何一個分區表中。
我們插入一些記錄:

INSERT INTO student (name,score) VALUES('Jim',77);INSERT INTO student (name,score) VALUES('Frank',56);INSERT INTO student (name,score) VALUES('Bean',88);INSERT INTO student (name,score) VALUES('John',47);INSERT INTO student (name,score) VALUES('Albert','87');INSERT INTO student (name,score) VALUES('Joey','60');

我們看下數據分布情況,是否分布到了正確的的分區表:

SELECT p.relname,c.tableoid,c.* FROM student c, pg_class pWHERE c.tableoid = p.oid

輸出如下:

我們看到,雖然我們插入的是大表,但是數據卻存在了對應的分區子表。符合我們的期望。同時還不影響查詢。

Rule是一個分流的辦法,還有TRIGGER也能做到讓正確的數據流向正確的分區子表。
首先我們定義個function。

CREATE OR REPLACE FUNCTION student_insert_trigger()RETURNS TRIGGER AS $$BEGIN   IF(NEW.score >= 60) THEN     INSERT INTO student_qualified VALUES (NEW.*);   ELSE      INSERT INTO student_nqualified VALUES (NEW.*);   END IF;   RETURN NULL;END;$$LANGUAGE plpgsql ;

然后定義TRIGGER,當插入到student之前,就會觸發trigger:

CREATE TRIGGER insert_student   BEFORE INSERT ON student  FOR EACH row  EXECUTE PROCEDURE student_insert_trigger() ;

我們首先通過刪除TABLE student,測試下trigger方式。

DROP TABLE STUDENT CASCADECREATE TABLE student (student_id bigserial, name varchar(32), score smallint) ;CREATE TABLE student_qualified (CHECK (score >= 60 )) INHERITS (student) ;CREATE TABLE student_nqualified (CHECK (score < 60)) INHERITS (student) ;

然后執行定義FUNCTION和定義TRIGGER的語句。就可以查看了。
為了確認我們的觸發器的確觸發了,我們打開存儲過程的統計開關:
在postgresql.conf中,找到track_functions,改成all

track_functions = all

插入之前先看下function student_insert_trigger的統計信息:

執行插入:

INSERT INTO student (name,score) VALUES('Jim',77);INSERT INTO student (name,score) VALUES('Frank',56);INSERT INTO student (name,score) VALUES('Bean',88);INSERT INTO student (name,score) VALUES('John',47);INSERT INTO student (name,score) VALUES('Albert','87');INSERT INTO student (name,score) VALUES('Joey','60');

插入后,看下function student_insert_trigger的統計信息

我們看到trigger觸發了6次。
執行下查詢:

SELECT p.relname,c.tableoid,c.* FROM student c, pg_class pWHERE c.tableoid = p.oid

輸出如下:

參考文獻

1 PostgreSQL document

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表

圖片精選

亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
久久九九有精品国产23| 日韩视频在线观看免费| 国产精品美女午夜av| 91视频免费在线| 亚洲美女视频网站| 91精品国产一区| 精品久久久久久久久久国产| 久久精品最新地址| 91亚洲精品久久久| 精品欧美一区二区三区| 欧美日韩免费看| 色香阁99久久精品久久久| 欧美性猛交视频| 亚洲免费电影一区| 亚洲成人aaa| 成人黄色免费片| 亚洲天堂成人在线| 青青草原一区二区| 懂色av中文一区二区三区天美| 精品中文字幕乱| 亚洲综合色激情五月| 一区二区亚洲欧洲国产日韩| 精品偷拍一区二区三区在线看| 欧美精品九九久久| 欧美日韩成人在线观看| 久久久欧美一区二区| 欧美日韩999| 在线观看成人黄色| 琪琪第一精品导航| 欧美大片免费观看| 欧美激情一二三| 最近2019年中文视频免费在线观看| 成人网在线视频| 亚洲欧美日韩图片| 91亚洲va在线va天堂va国| 91在线播放国产| 亚洲欧美制服中文字幕| 色哟哟入口国产精品| 日韩国产精品视频| 韩剧1988在线观看免费完整版| 国产亚洲精品美女久久久久| 欧美性色xo影院| 欧美日韩第一视频| 91视频-88av| 日韩精品免费在线视频观看| 亚洲精品视频免费| 欧美日韩午夜剧场| 中文字幕亚洲无线码a| 精品国产91乱高清在线观看| 国产大片精品免费永久看nba| 欧美大片网站在线观看| 一区二区三区国产视频| 欧美性猛交xxxxx免费看| 精品无人国产偷自产在线| 国产成人涩涩涩视频在线观看| 国产ts一区二区| 日产精品99久久久久久| 中文亚洲视频在线| 国产精品一久久香蕉国产线看观看| 日韩激情视频在线播放| 欧美另类极品videosbest最新版本| 亚洲国内高清视频| 不卡在线观看电视剧完整版| 欧美激情videoshd| 久热国产精品视频| 欧美成人免费网| 亚洲在线视频福利| 国产视频久久久久| 九九视频直播综合网| 亚洲18私人小影院| 亚洲国产欧美在线成人app| 国产成人免费91av在线| 日韩高清电影免费观看完整| 午夜剧场成人观在线视频免费观看| 欧美第一黄网免费网站| 久久久久久久久久久网站| 97福利一区二区| 18性欧美xxxⅹ性满足| 成人a在线视频| 日本成人精品在线| 欧美激情视频播放| 国产一区二区三区高清在线观看| 久久久精品国产亚洲| 日本a级片电影一区二区| 久久久久久久电影一区| 欧美在线一区二区三区四| 亚洲国产成人久久综合一区| 国产精品爱啪在线线免费观看| 亚洲欧美国产高清va在线播| 精品国产精品自拍| 久久不射电影网| 日韩电影中文字幕一区| 日本国产高清不卡| 亚洲国产精久久久久久久| 久久国产色av| 国产精品久久二区| 91精品国产91久久| 欧美成人第一页| 久久精品成人欧美大片| 欧美有码在线视频| 亚洲香蕉成视频在线观看| 欧美巨猛xxxx猛交黑人97人| 777午夜精品福利在线观看| 久久久久久国产精品三级玉女聊斋| 欧美华人在线视频| 亚洲最大福利视频网站| 精品久久久视频| 亚洲一区二区福利| 日韩精品中文字幕视频在线| 97视频色精品| 欧美激情一区二区三区在线视频观看| 91探花福利精品国产自产在线| 国产精品极品尤物在线观看| 福利一区福利二区微拍刺激| 正在播放亚洲1区| 日韩亚洲一区二区| 久久av红桃一区二区小说| 中文字幕欧美精品在线| 91在线高清免费观看| 日本一区二区在线播放| 久久成人在线视频| 亚洲欧美在线第一页| 亚洲一二三在线| 欧美日韩黄色大片| 久久久久久亚洲精品中文字幕| 视频一区视频二区国产精品| 欧美极品少妇xxxxⅹ喷水| 久久av.com| 91在线免费看网站| 国产专区欧美专区| 国产日韩欧美一二三区| 久久国产精品久久久久久久久久| 日韩人体视频一二区| 欧美在线免费观看| 狠狠综合久久av一区二区小说| 欧洲亚洲免费在线| 亚洲欧美日本精品| 精品中文视频在线| 日韩av在线网站| 精品中文字幕在线| 亚洲色图25p| 国产精品欧美日韩一区二区| 在线中文字幕日韩| 精品久久中文字幕久久av| 久久777国产线看观看精品| 91亚洲精品久久久久久久久久久久| 午夜欧美大片免费观看| 91精品在线看| 成人久久久久爱| 欧美一区二区三区精品电影| 97超级碰碰人国产在线观看| 色无极亚洲影院| 欧美电影免费观看电视剧大全| 欧美性生活大片免费观看网址| 91在线观看欧美日韩| 亚洲精品乱码久久久久久金桔影视| 日韩电影免费观看中文字幕| 久久久久国产视频| 超碰日本道色综合久久综合| 亚洲免费视频在线观看| 久久中文字幕在线| 97久久精品视频| 亚洲综合一区二区不卡| 精品人伦一区二区三区蜜桃免费|