<span id="mktg5"></span>

<i id="mktg5"><meter id="mktg5"></meter></i>

        <label id="mktg5"><meter id="mktg5"></meter></label>
        最新文章專題視頻專題問答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或者_yyyymm后綴進行分區(qū)的,那么可以用這個函數(shù)進行添加分區(qū) CREATE OR REPLACE FUNCTION f_add_partition()RETURNS voidLANGUAGE pl
        推薦度:
        導(dǎo)讀Postgresql添加分區(qū)表(按月和按日通用):建了分區(qū)表的同學(xué)相信添加分區(qū)表很頭疼,如果有按月分區(qū)又有按日分區(qū)的,而且是通過_yyyymmdd或者_yyyymm后綴進行分區(qū)的,那么可以用這個函數(shù)進行添加分區(qū) CREATE OR REPLACE FUNCTION f_add_partition()RETURNS voidLANGUAGE pl

        建了分區(qū)表的同學(xué)相信添加分區(qū)表很頭疼,如果有按月分區(qū)又有按日分區(qū)的,而且是通過_yyyymmdd或者_yyyymm后綴進行分區(qū)的,那么可以用這個函數(shù)進行添加分區(qū) CREATE OR REPLACE FUNCTION f_add_partition()RETURNS voidLANGUAGE plpgsqlAS $function$declarev_

        建了分區(qū)表的同學(xué)相信添加分區(qū)表很頭疼,如果有按月分區(qū)又有按日分區(qū)的,而且是通過"_yyyymmdd"或者"_yyyymm"后綴進行分區(qū)的,那么可以用這個函數(shù)進行添加分區(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或者_yyyymm后綴進行分區(qū)的,那么可以用這個函數(shù)進行添加分區(qū) CREATE OR REPLACE FUNCTION f_add_partition()RETURNS voidLANGUAGE pl
        推薦度:
        標簽: 添加 通用 按月
        • 熱門焦點

        最新推薦

        猜你喜歡

        熱門推薦

        專題
        Top
        主站蜘蛛池模板: 免费A级毛片无码A∨ | 99人中文字幕亚洲区| 亚洲午夜国产精品无码| 亚洲高清国产拍精品26U| 亚洲成在人线电影天堂色| 亚洲熟妇无码一区二区三区导航| 性色av极品无码专区亚洲| 一区二区免费在线观看| 久久成人a毛片免费观看网站| 国产精品视频免费观看| 亚洲成a人片在线观看老师| 亚洲av网址在线观看| 日韩色视频一区二区三区亚洲 | 亚洲gay片在线gv网站| 中文字幕免费在线| 亚洲色偷偷狠狠综合网| 亚洲网红精品大秀在线观看| 亚洲国产视频一区| 四虎国产精品免费久久| 亚洲码国产精品高潮在线| 免费成人高清在线视频| 亚洲一区无码精品色| 日本免费久久久久久久网站| 亚洲最大黄色网站| 国产中文字幕免费观看| 亚洲视频国产精品| 一区二区无码免费视频网站| 亚洲国产精品无码久久久秋霞1| 亚洲AV无码乱码在线观看牲色| baoyu116.永久免费视频| 亚洲国产精品狼友中文久久久| 九九热久久免费视频| 免费h黄肉动漫在线观看| 亚洲专区中文字幕| 最近免费中文字幕MV在线视频3| 免费一看一级毛片| 久久国产乱子精品免费女| 亚洲导航深夜福利| 亚洲中文字幕丝袜制服一区| 99在线在线视频免费视频观看| 亚洲人成电影网站免费|