> 데이터 베이스 > MySQL 튜토리얼 > Postgresql 添加分区表(按月和按日通用)

Postgresql 添加分区表(按月和按日通用)

WBOY
풀어 주다: 2016-06-07 14:50:16
원래의
3148명이 탐색했습니다.

建了分区表的同学相信添加分区表很头疼,如果有按月分区又有按日分区的,而且是通过_yyyymmdd或者_yyyymm后缀进行分区的,那么可以用这个函数进行添加分区 CREATE OR REPLACE FUNCTION f_add_partition()RETURNS voidLANGUAGE plpgsqlAS $function$declarev_

建了分区表的同学相信添加分区表很头疼,如果有按月分区又有按日分区的,而且是通过"_yyyymmdd"或者"_yyyymm"后缀进行分区的,那么可以用这个函数进行添加分区
CREATE OR REPLACE FUNCTION f_add_partition()  RETURNS void  LANGUAGE plpgsql AS $function$ declare v_max_childname text;  --最大子表名称 v_parentname text;  --子表对应的父表名称 v_suffix text;  --子表日期后缀 sql text; --要执行的SQL语句 GRA_TO text;   --赋予权限的语句 begin --取出分区表最大分区表以及父表名称 for v_max_childname, v_parentname in select max(inhrelid::regclass::text),inhparent::regclass from pg_inherits where  inhparent::regclass::text not like '%.%' group by inhparent     loop     raise notice '最大子表:%,父表:%',v_max_childname,v_parentname;       sql= 'select split_part('''|| v_max_childname  || ''',''_'',(length(''' || v_max_childname || ''')-length(replace(''' || v_max_childname || ''',''_'',''''))+1))';   --取出日期是按月还是按日     execute sql into v_suffix;      --将取出的日期存入v_suffix      while(length(v_suffix)=6 and v_suffix \dt   hank   | tbl              | table | hank  hank   | tbl_20140322     | table | hank  hank   | test             | table | hank  hank   | test_201405      | table | hank select f_add_partition(); \dt
 hank   | tbl              | table | hank  hank   | tbl_20140322     | table | hank  按日分区的显示太多,此处省略一万行。。。。。  hank   | tbl_20151230     | table | hank  hank   | tbl_20151231     | table | hank
按月的比较少,就全部贴出来了  hank   | test             | table | hank  hank   | test_201405      | table | hank  hank   | test_201406      | table | hank  hank   | test_201407      | table | hank  hank   | test_201408      | table | hank  hank   | test_201409      | table | hank  hank   | test_201410      | table | hank  hank   | test_201411      | table | hank  hank   | test_201412      | table | hank  hank   | test_201501      | table | hank  hank   | test_201502      | table | hank  hank   | test_201503      | table | hank  hank   | test_201504      | table | hank  hank   | test_201505      | table | hank  hank   | test_201506      | table | hank  hank   | test_201507      | table | hank  hank   | test_201508      | table | hank  hank   | test_201509      | table | hank  hank   | test_201510      | table | hank  hank   | test_201511      | table | hank  hank   | test_201512      | table | hank
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿