首页 行业资讯 宠物日常 宠物养护 宠物健康 宠物故事

ORACLE每天创建一个分区表

发布网友 发布时间:2022-04-26 19:33

我来回答

2个回答

懂视网 时间:2022-04-07 22:03

DECLARE V_SQL VARCHAR2(1000);
 V_SQL_HEAD VARCHAR2(100);
 V_SQL_TAIL VARCHAR2(10);
 V_DAY VARCHAR2(8); CURSOR C_CUR IS SELECT TO_CHAR((TO_DATE(‘2012-01‘, ‘yyyy-mm‘) + (ROWNUM - 1)), ‘YYYYMMDD‘) S_DATE FROM DUAL
 CONNECT BY ROWNUM <= LAST_DAY(TO_DATE(‘2012-12‘, ‘yyyy-mm‘)) - TO_DATE(‘2012-01‘, ‘yyyy-mm‘) + 1; BEGIN DBMS_OUTPUT.ENABLE(1000000); OPEN C_CUR;
 V_SQL_HEAD := ‘PARTITION BY RANGE(ACCT_DAY)‘ || CHR(13) || ‘(‘;
 V_SQL_TAIL := CHR(13) || ‘)‘;
 DBMS_OUTPUT.PUT_LINE(V_SQL_HEAD);
 LOOP FETCH C_CUR INTO V_DAY; EXIT WHEN C_CUR%NOTFOUND;
 V_SQL := ‘PARTITION PART_‘ || V_DAY || ‘ ‘ || ‘VALUES LESS THAN (‘‘‘ || TO_CHAR((TO_DATE(V_DAY, ‘YYYYMMDD‘) + 1), ‘YYYYMMDD‘) || ‘‘‘)‘;
 DBMS_OUTPUT.PUT_LINE(V_SQL); END LOOP;
 DBMS_OUTPUT.PUT_LINE(V_SQL_TAIL); CLOSE C_CUR; END;
技术分享

      该语句执行之后的效果就是生成了2012年一年的分区,不重不漏。具体情况具体修改。勿喷。

oracle建表时按天分区的自动生成语句

标签:

热心网友 时间:2022-04-07 19:11

可以拼出sql的字符串后用动态sql执行
不过11g有分区表自动增加分区的特性,这个更方便

声明声明:本网页内容为用户发布,旨在传播知识,不代表本网认同其观点,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。E-MAIL:11247931@qq.com