Postgresql添加分區(qū)表(按月和按日通用)
來源:懂視網(wǎng)
責(zé)編:小采
時間:2020-11-09 16:29:43
Postgresql添加分區(qū)表(按月和按日通用)
Postgresql添加分區(qū)表(按月和按日通用):建了分區(qū)表的同學(xué)相信添加分區(qū)表很頭疼,如果有按月分區(qū)又有按日分區(qū)的,而且是通過_yyyymmdd或者_(dá)yyyymm后綴進(jìn)行分區(qū)的,那么可以用這個函數(shù)進(jìn)行添加分區(qū) CREATE OR REPLACE FUNCTION f_add_partition()RETURNS voidLANGUAGE pl
導(dǎo)讀Postgresql添加分區(qū)表(按月和按日通用):建了分區(qū)表的同學(xué)相信添加分區(qū)表很頭疼,如果有按月分區(qū)又有按日分區(qū)的,而且是通過_yyyymmdd或者_(dá)yyyymm后綴進(jìn)行分區(qū)的,那么可以用這個函數(shù)進(jìn)行添加分區(qū) CREATE OR REPLACE FUNCTION f_add_partition()RETURNS voidLANGUAGE pl
建了分區(qū)表的同學(xué)相信添加分區(qū)表很頭疼,如果有按月分區(qū)又有按日分區(qū)的,而且是通過_yyyymmdd或者_(dá)yyyymm后綴進(jìn)行分區(qū)的,那么可以用這個函數(shù)進(jìn)行添加分區(qū) CREATE OR REPLACE FUNCTION f_add_partition()RETURNS voidLANGUAGE plpgsqlAS $function$declarev_
建了分區(qū)表的同學(xué)相信添加分區(qū)表很頭疼,如果有按月分區(qū)又有按日分區(qū)的,而且是通過"_yyyymmdd"或者"_yyyymm"后綴進(jìn)行分區(qū)的,那么可以用這個函數(shù)進(jìn)行添加分區(qū)
CREATE OR REPLACE FUNCTION f_add_partition()
RETURNS void
LANGUAGE plpgsql
AS $function$
declare
v_max_childname text; --最大子表名稱
v_parentname text; --子表對應(yīng)的父表名稱
v_suffix text; --子表日期后綴
sql text; --要執(zhí)行的SQL語句
GRA_TO text; --賦予權(quán)限的語句
begin
--取出分區(qū)表最大分區(qū)表以及父表名稱
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<'201512') --判斷如果是按月,那么循環(huán)執(zhí)行建表語句并且賦予權(quán)限
loop
v_suffix=to_char (to_timestamp(v_suffix,'yyyymm')+interval '1 month','yyyymm') ; --在取出的分區(qū)表日期按月+1
sql= 'create table '||v_parentname ||'_'||v_suffix || '(like ' || v_parentname ||' including all) inherits ('|| v_parentname ||')';
execute sql;
for GRA_TO in execute 'select ''grant ''||privilege_type||'' on '||v_parentname||'_'||v_suffix ||' to ''||grantee from information_schema.table_privileges where table_name='''||v_max_childname||'''' loop
execute GRA_TO;
end loop;
end loop;
while(length(v_suffix)=8 and v_suffix<'20151231') --判斷如果是按日分區(qū),循環(huán)執(zhí)行后面的建表語句并且賦予權(quán)限
loop
v_suffix=to_char (to_timestamp(v_suffix,'yyyymmdd')+interval '1 day','yyyymmdd') ;
sql= 'create table '||v_parentname||'_'||v_suffix || '(like ' || v_parentname ||' including all) inherits ('|| v_parentname ||')';
execute sql;
for GRA_TO in execute 'select ''grant ''||privilege_type||'' on '||v_parentname||'_'||v_suffix||' to ''||grantee from information_schema.table_privileges where table_name='''||v_max_childname||'''' loop
execute GRA_TO;
end loop;
end loop;
end loop;
RAISE NOTICE 'Partition table has be created successfully!';
end;
$function$
\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
按日分區(qū)的顯示太多,此處省略一萬行。。。
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
聲明:本網(wǎng)頁內(nèi)容旨在傳播知識,若有侵權(quán)等問題請及時與本網(wǎng)聯(lián)系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com
Postgresql添加分區(qū)表(按月和按日通用)
Postgresql添加分區(qū)表(按月和按日通用):建了分區(qū)表的同學(xué)相信添加分區(qū)表很頭疼,如果有按月分區(qū)又有按日分區(qū)的,而且是通過_yyyymmdd或者_(dá)yyyymm后綴進(jìn)行分區(qū)的,那么可以用這個函數(shù)進(jìn)行添加分區(qū) CREATE OR REPLACE FUNCTION f_add_partition()RETURNS voidLANGUAGE pl