Oracle
 sql >> डेटाबेस >  >> RDS >> Oracle

आईडी द्वारा Oracle विभाजन और अंतराल के साथ DATE तक उप-विभाजन

आप एक RANGE INTERVAL बना सकते हैं दिनांक पर विभाजन और फिर LIST या RANGE उस पर विभाजन। ऐसा होगा:

CREATE TABLE MY_PART_TABLE
(
  CUSTOMER_ID                      NUMBER             NOT NULL,
  THE_DATE                 TIMESTAMP(0) NOT NULL,
  OTHER_COLUMNS NUMBER
)
PARTITION BY RANGE (THE_DATE) INTERVAL (INTERVAL '1' MONTH)
    SUBPARTITION BY RANGE (CUSTOMER_ID)
        SUBPARTITION TEMPLATE (
        SUBPARTITION CUSTOMER_GROUP_1 VALUES LESS THAN (10),
        SUBPARTITION CUSTOMER_GROUP_2 VALUES LESS THAN (20),
        SUBPARTITION CUSTOMER_GROUP_3 VALUES LESS THAN (30),
        SUBPARTITION CUSTOMER_GROUP_4 VALUES LESS THAN (40),
        SUBPARTITION CUSTOMER_GROUP_5 VALUES LESS THAN (MAXVALUE)
        )
(PARTITION VALUES LESS THAN ( TIMESTAMP '2015-01-01 00:00:00') );



CREATE TABLE MY_PART_TABLE
(
  CUSTOMER_ID                      NUMBER             NOT NULL,
  THE_DATE                 TIMESTAMP(0) NOT NULL,
  OTHER_COLUMNS NUMBER
)
PARTITION BY RANGE (THE_DATE) INTERVAL (INTERVAL '1' MONTH)
    SUBPARTITION BY LIST (CUSTOMER_ID)
        SUBPARTITION TEMPLATE (
        SUBPARTITION CUSTOMER_1 VALUES (1),
        SUBPARTITION CUSTOMER_2 VALUES (2),
        SUBPARTITION CUSTOMER_3_to_6 VALUES (3,4,5,6),
        SUBPARTITION CUSTOMER_7 VALUES (7)
        )
(PARTITION VALUES LESS THAN ( TIMESTAMP '2015-01-01 00:00:00') );

ध्यान दें, दूसरे समाधान के लिए ग्राहक का नंबर (यानी आईडी) तय है। यदि आपको नए ग्राहक मिलते हैं तो आपको तालिका में परिवर्तन करना होगा और तदनुसार सबपार्टिशन टेम्पलेट को संशोधित करना होगा।

जब भी नए मान डाले या अपडेट किए जाएंगे, तब Oracle द्वारा मासिक विभाजन स्वचालित रूप से बनाए जाएंगे।




  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. डायनामिक सर्च स्ट्रिंग्स के लिए इंडेक्स कैसे बनाएं

  2. SQL Oracle:एक खाली परिणाम को शब्द से बदलें

  3. तालिका में सम्मिलित करें तालिका a और तालिका b से चुनें जहां

  4. SQLException प्राप्त करें java.sql.SQLException:ResultSet.next को कॉल नहीं किया गया था

  5. Oracle ORA-00979 - अभिव्यक्ति द्वारा समूह नहीं