国产99久久精品_欧美日本韩国一区二区_激情小说综合网_欧美一级二级视频_午夜av电影_日本久久精品视频

最新文章專題視頻專題問答1問答10問答100問答1000問答2000關鍵字專題1關鍵字專題50關鍵字專題500關鍵字專題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關鍵字專題關鍵字專題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
當前位置: 首頁 - 科技 - 知識百科 - 正文

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

來源:懂視網 責編:小采 時間:2020-11-09 16:29:43
文檔

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

Postgresql添加分區表(按月和按日通用):建了分區表的同學相信添加分區表很頭疼,如果有按月分區又有按日分區的,而且是通過_yyyymmdd或者_yyyymm后綴進行分區的,那么可以用這個函數進行添加分區 CREATE OR REPLACE FUNCTION f_add_partition()RETURNS voidLANGUAGE pl
推薦度:
導讀Postgresql添加分區表(按月和按日通用):建了分區表的同學相信添加分區表很頭疼,如果有按月分區又有按日分區的,而且是通過_yyyymmdd或者_yyyymm后綴進行分區的,那么可以用這個函數進行添加分區 CREATE OR REPLACE FUNCTION f_add_partition()RETURNS voidLANGUAGE pl

建了分區表的同學相信添加分區表很頭疼,如果有按月分區又有按日分區的,而且是通過_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<'201512') --判斷如果是按月,那么循環執行建表語句并且賦予權限 loop v_suffix=to_char (to_timestamp(v_suffix,'yyyymm')+interval '1 month','yyyymm') ; --在取出的分區表日期按月+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') --判斷如果是按日分區,循環執行后面的建表語句并且賦予權限 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 按日分區的顯示太多,此處省略一萬行。。。 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

聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

文檔

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

Postgresql添加分區表(按月和按日通用):建了分區表的同學相信添加分區表很頭疼,如果有按月分區又有按日分區的,而且是通過_yyyymmdd或者_yyyymm后綴進行分區的,那么可以用這個函數進行添加分區 CREATE OR REPLACE FUNCTION f_add_partition()RETURNS voidLANGUAGE pl
推薦度:
標簽: 添加 通用 按月
  • 熱門焦點

最新推薦

猜你喜歡

熱門推薦

專題
Top
主站蜘蛛池模板: 欧美日韩亚洲区久久综合 | 国产成人99久久亚洲综合精品 | 女人18毛片a级毛片一区②区 | 欧美性第一页 | 成人黄色一级视频 | 欧美日韩国产va另类试看 | 日韩美一区二区 | 欧美色图日韩色图 | 日韩 亚洲 制服 欧美 综合 | 欧美网站在线 | 成人毛片一区二区三区 | 91久久精品国产亚洲 | 精品国产成人综合久久小说 | 久久国产一级毛片一区二区 | 成人精品一级毛片 | 无毛片 | 国产精品成人69xxx免费视频 | 国产精品免费看 | 在线视频日韩 | 高清亚洲| 欧美 韩国 精品 另类 综合 | 国产一级一片免费播放视频 | 欧美精品在线免费观看 | 一级免费a | 精品国产一区二区三区久久久狼 | 日韩黄| 丝袜影音先锋 | 精品欧美日韩一区二区三区 | 永久在线毛片免费观看 | 一区二区三区亚洲 | 日韩视频在线观看一区二区 | 在线观看亚洲专区 | 日韩视频在线播放 | 亚洲 自拍 另类 欧美 综合 | 久久99久久精品国产99热 | 久久综合中文字幕一区二区 | 精品一区二区三区视频日产 | 全部费免一级毛片不收费 | 五月天婷婷基地 | 亚洲人成网站999久久久综合 | 中文字幕第一区 |