建了分区表的同学相信添加分区表很头疼,如果有按月分区又有按日分区的,而且是通过_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
Stellungnahme:Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn