亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

PostgreSQL之分區(qū)表(partitioning)

 更新時(shí)間:2016年11月28日 22:25:18   投稿:mdxy-dxy  
通過(guò)合理的設(shè)計(jì),可以將選擇一定的規(guī)則,將大表切分多個(gè)不重不漏的子表,這就是傳說(shuō)中的partitioning。比如,我們可以按時(shí)間切分,每天一張子表,比如我們可以按照某其他字段分割,總之了就是化整為零,提高查詢(xún)的效能

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

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

怎么實(shí)現(xiàn)這個(gè)分區(qū)表的功能呢?
   1 建立大表。
   2 創(chuàng)建分區(qū)繼承
   3 定義Rule或者Trigger?

下面根據(jù)一個(gè)簡(jiǎn)單的例子,描述這個(gè)過(guò)程。我們將學(xué)生按照低于60分和不低于60分切分成兩張子表。

   1 建立大表   

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

   2 創(chuàng)建分區(qū)繼承。

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

創(chuàng)建了兩個(gè)分區(qū)表,student_qualified和student_nqualified,繼承了大表student的一切字段,同時(shí)設(shè)定了約束,即CHECK條件。

3 定義Rule或者Trigger。

   雖然我們定義了CHECK條件,但是往student插入數(shù)據(jù)時(shí),PostgreSQL并不能根據(jù)score是否低于60插入的正確的子表,原因是,你并沒(méi)有定義這種規(guī)則,來(lái)告訴數(shù)據(jù)這么做。我們需要定義Rule或者Trigger,將數(shù)據(jù)插入到正確的分區(qū)表。
   先看下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.*);

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

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');

我們看下數(shù)據(jù)分布情況,是否分布到了正確的的分區(qū)表:

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

輸出如下:

我們看到,雖然我們插入的是大表,但是數(shù)據(jù)卻存在了對(duì)應(yīng)的分區(qū)子表。符合我們的期望。同時(shí)還不影響查詢(xún)。

Rule是一個(gè)分流的辦法,還有TRIGGER也能做到讓正確的數(shù)據(jù)流向正確的分區(qū)子表。
首先我們定義個(gè)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,當(dāng)插入到student之前,就會(huì)觸發(fā)trigger:

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

我們首先通過(guò)刪除TABLE student,測(cè)試下trigger方式。

DROP TABLE STUDENT CASCADE

CREATE 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) ;

然后執(zhí)行定義FUNCTION和定義TRIGGER的語(yǔ)句。就可以查看了。
為了確認(rèn)我們的觸發(fā)器的確觸發(fā)了,我們打開(kāi)存儲(chǔ)過(guò)程的統(tǒng)計(jì)開(kāi)關(guān):
在postgresql.conf中,找到track_functions,改成all

track_functions = all

插入之前先看下function student_insert_trigger的統(tǒng)計(jì)信息:

執(zhí)行插入:

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的統(tǒng)計(jì)信息

我們看到trigger觸發(fā)了6次。
執(zhí)行下查詢(xún):

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

輸出如下:

參考文獻(xiàn)

1 PostgreSQL document

相關(guān)文章

  • PostgreSQL數(shù)據(jù)庫(kù)如何定期清理歸檔(pg_wal)日志

    PostgreSQL數(shù)據(jù)庫(kù)如何定期清理歸檔(pg_wal)日志

    在?般的?產(chǎn)環(huán)境中,數(shù)據(jù)庫(kù)都需要開(kāi)啟歸檔模式,下面這篇文章主要給大家介紹了關(guān)于PostgreSQL數(shù)據(jù)庫(kù)如何定期清理歸檔(pg_wal)日志的相關(guān)資料,文中通過(guò)代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2024-05-05
  • postgresql數(shù)據(jù)庫(kù)配置文件postgresql.conf,pg_hba.conf,pg_ident.conf

    postgresql數(shù)據(jù)庫(kù)配置文件postgresql.conf,pg_hba.conf,pg_ident.conf

    這篇文章主要為大家介紹了postgresql數(shù)據(jù)庫(kù)中三個(gè)重要的配置文件postgresql.conf,pg_hba.conf,pg_ident.conf使用示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-02-02
  • postgresql高級(jí)應(yīng)用之合并單元格的思路詳解

    postgresql高級(jí)應(yīng)用之合并單元格的思路詳解

    這篇文章主要介紹了postgresql高級(jí)應(yīng)用之合并單元格,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2021-05-05
  • postgresql 循環(huán)函數(shù)的簡(jiǎn)單實(shí)現(xiàn)操作

    postgresql 循環(huán)函數(shù)的簡(jiǎn)單實(shí)現(xiàn)操作

    這篇文章主要介紹了postgresql 循環(huán)函數(shù)的簡(jiǎn)單實(shí)現(xiàn)操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2021-01-01
  • postgresql 實(shí)現(xiàn)修改jsonb字段中的某一個(gè)值

    postgresql 實(shí)現(xiàn)修改jsonb字段中的某一個(gè)值

    這篇文章主要介紹了postgresql 實(shí)現(xiàn)修改jsonb字段中的某一個(gè)值操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2021-01-01
  • PostgreSQL慢SQL的定位排查方法

    PostgreSQL慢SQL的定位排查方法

    所謂慢SQL 是指在數(shù)據(jù)庫(kù)中執(zhí)行時(shí)間超過(guò)指定閾值的語(yǔ)句,慢查詢(xún)太多,對(duì)于業(yè)務(wù)而言,是有很大風(fēng)險(xiǎn)的,可能隨時(shí)都會(huì)因?yàn)槟撤N原因而被觸發(fā),本篇文章將介紹 PostgreSQL 慢 SQL 如何定位排查,需要的朋友可以參考下
    2024-07-07
  • postgresql無(wú)則插入,有則更新問(wèn)題

    postgresql無(wú)則插入,有則更新問(wèn)題

    這篇文章主要介紹了postgresql無(wú)則插入,有則更新問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-04-04
  • PostgreSQL教程(十五):系統(tǒng)表詳解

    PostgreSQL教程(十五):系統(tǒng)表詳解

    這篇文章主要介紹了PostgreSQL教程(十五):系統(tǒng)表詳解,本文講解了pg_class、pg_attribute、pg_attrdef、pg_authid、pg_auth_members、pg_constraint、pg_tablespace、pg_namespace、pg_database等表的作用和字段介紹,需要的朋友可以參考下
    2015-05-05
  • Windows版?PostgreSQL?利用?pg_upgrade?進(jìn)行大版升級(jí)操作方法

    Windows版?PostgreSQL?利用?pg_upgrade?進(jìn)行大版升級(jí)操作方法

    最近?PostgreSQL?15?版本正式發(fā)布了,新版本的各種特性和好處本文就不展開(kāi)介紹了,主要介紹一下?Windows?環(huán)境下?PostgreSQL?大版本升級(jí)的方法,我們現(xiàn)在的幾個(gè)數(shù)據(jù)庫(kù)都是運(yùn)行在?Windows服務(wù)器的?PostgreSQL?14,需要的朋友可以參考下
    2022-10-10
  • Ubuntu中卸載Postgresql出錯(cuò)的解決方法

    Ubuntu中卸載Postgresql出錯(cuò)的解決方法

    這篇文章主要給大家介紹了關(guān)于在Ubuntu中卸載Postgresql出錯(cuò)的解決方法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧。
    2017-09-09

最新評(píng)論