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

首頁 > 數據庫 > PostgreSQL > 正文

PostgreSQL之分區表(partitioning)

2020-03-12 23:52:17
字體:
來源:轉載
供稿:網友

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

輸出如下:

PostgreSQL,分區表,partitioning

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

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的統計信息:

PostgreSQL,分區表,partitioning

執行插入:

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的統計信息

PostgreSQL,分區表,partitioning

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

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

輸出如下:

PostgreSQL,分區表,partitioning

參考文獻

1 PostgreSQL document


注:相關教程知識閱讀請移步到PostgreSQL頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产精品视频区1| 欧美日韩性视频在线| 日韩视频一区在线| 午夜免费久久久久| 国产成人综合精品在线| 亚洲成人av片在线观看| 亚洲成年人在线| 久操成人在线视频| 大桥未久av一区二区三区| 亚洲国产一区二区三区四区| 91在线免费网站| 97视频人免费观看| 亚洲女人天堂色在线7777| 国产69精品久久久久久| 日韩欧美在线看| 福利精品视频在线| 成人黄色中文字幕| 青青草原一区二区| 神马国产精品影院av| 亚洲精品国精品久久99热| 国产精品黄色av| 日韩精品免费电影| 久久五月情影视| 日韩在线播放一区| 亚洲精品国偷自产在线99热| 91精品国产高清久久久久久久久| 日韩69视频在线观看| 亚洲国产日韩一区| 51午夜精品视频| 欧美极品少妇xxxxⅹ喷水| 亚洲人成自拍网站| 在线观看视频亚洲| 国产视频精品自拍| 91大神在线播放精品| 国产亚洲精品va在线观看| 91九色国产在线| 亚洲精品网站在线播放gif| 久久久亚洲欧洲日产国码aⅴ| 亚洲综合中文字幕68页| 亚洲精品美女免费| 亚洲精品午夜精品| 亚洲人a成www在线影院| 久久久久亚洲精品| 一道本无吗dⅴd在线播放一区| 最新的欧美黄色| 国产精品视频一区国模私拍| 欧美精品video| 欧美xxxx14xxxxx性爽| 亚洲自拍偷拍色图| 亚洲国产成人久久综合一区| 久久6免费高清热精品| 91亚洲精华国产精华| 7m第一福利500精品视频| 亚洲在线免费视频| 国产精品国产三级国产专播精品人| 一级做a爰片久久毛片美女图片| 国内精品视频一区| 久久精品国产精品亚洲| 亚洲欧洲国产精品| 日韩美女av在线免费观看| 国产在线久久久| 亚洲午夜精品久久久久久久久久久久| 91久久精品国产91久久性色| 91精品国产777在线观看| 国产视频精品免费播放| 日韩亚洲第一页| 欧美成人免费一级人片100| 日韩视频在线免费观看| 国产91精品最新在线播放| 国产精品扒开腿做爽爽爽男男| xxxxx91麻豆| 亚洲美女免费精品视频在线观看| 精品久久久久久久久久国产| 精品福利免费观看| 欧美性高潮床叫视频| 欧美又大粗又爽又黄大片视频| 精品久久久久久久久久| 日韩欧美第一页| 成人激情视频免费在线| 91久久国产精品| 国产日韩精品入口| 国产精品久久久久久久久影视| 国产美女久久精品香蕉69| 高潮白浆女日韩av免费看| 91国内在线视频| 中文字幕无线精品亚洲乱码一区| 亚洲国产日韩精品在线| 国产91久久婷婷一区二区| 中文字幕在线国产精品| 久久九九免费视频| 国产v综合v亚洲欧美久久| 欧美与欧洲交xxxx免费观看| 69国产精品成人在线播放| 久久久久免费精品国产| 国产精品专区h在线观看| 日本不卡免费高清视频| 91精品国产高清久久久久久久久| 麻豆乱码国产一区二区三区| 国内精品伊人久久| 美日韩在线视频| 在线国产精品视频| 欧洲亚洲在线视频| 欧美交受高潮1| 亚洲男人的天堂在线| 国产中文日韩欧美| 国产精品女人网站| 日韩精品中文字幕有码专区| 日韩av在线网| 奇米影视亚洲狠狠色| 成人在线观看视频网站| 国产成人亚洲综合青青| 中文字幕一精品亚洲无线一区| 亚洲欧洲在线免费| 91精品国产高清自在线| 日韩精品日韩在线观看| 伦理中文字幕亚洲| 久久天堂电影网| 亚洲欧美日韩另类| 尤物精品国产第一福利三区| 成人国产精品色哟哟| 欧美又大又粗又长| 亚洲另类激情图| 久久av在线看| 热99久久精品| 国产在线一区二区三区| 国产精品久久久久久久久久尿| 国产精品久久久久9999| 亚洲 日韩 国产第一| 亚洲精品之草原avav久久| 成人av.网址在线网站| 色无极影院亚洲| 57pao成人永久免费视频| 久久综合九色九九| 九九热精品视频在线播放| 日韩在线国产精品| 国产精品亚洲аv天堂网| 国产亚洲免费的视频看| 亚洲美女福利视频网站| 亚洲精品小视频在线观看| 久久久久久久亚洲精品| 欧美在线影院在线视频| 亚洲精品免费在线视频| 日韩精品中文字幕视频在线| 亚洲成人激情小说| 久久久久久999| 国产成人一区三区| 亚洲女人天堂av| 亚洲精品成a人在线观看| 欧美激情三级免费| 伊人一区二区三区久久精品| 欧美日韩国产麻豆| 日韩中文字幕欧美| 日韩免费不卡av| 欧美精品在线免费观看| 奇米四色中文综合久久| 亚洲午夜av电影| 欧美放荡办公室videos4k| 亚洲欧美精品伊人久久| 97久久精品人人澡人人爽缅北| 国产91精品久久久久| 欧美最猛性xxxxx亚洲精品| 欧美午夜视频在线观看| 77777亚洲午夜久久多人| 国产成人精品日本亚洲专区61|