最新文章專題視頻專題問答1問答10問答100問答1000問答2000關(guān)鍵字專題1關(guān)鍵字專題50關(guān)鍵字專題500關(guān)鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關(guān)鍵字專題關(guān)鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
問答文章1 問答文章501 問答文章1001 問答文章1501 問答文章2001 問答文章2501 問答文章3001 問答文章3501 問答文章4001 問答文章4501 問答文章5001 問答文章5501 問答文章6001 問答文章6501 問答文章7001 問答文章7501 問答文章8001 問答文章8501 問答文章9001 問答文章9501
當(dāng)前位置: 首頁 - 科技 - 知識百科 - 正文

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
推薦度:
標(biāo)簽: 添加 通用 按月
  • 熱門焦點(diǎn)

最新推薦

猜你喜歡

熱門推薦

專題
Top