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

技术分享
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年一年的分区,不重不漏。具体情况具体修改。勿喷。

郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。