Oracle
 sql >> Cơ Sở Dữ Liệu >  >> RDS >> Oracle

Phân vùng Oracle theo ID và phân vùng con theo DATE với khoảng thời gian

Bạn có thể tạo RANGE INTERVAL phân vùng vào ngày và sau đó là LIST hoặc RANGE phân vùng con trên đó. Sẽ như thế này:

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') );

Lưu ý, đối với giải pháp thứ hai, số (tức là ID) của khách hàng được sửa. Nếu bạn có được khách hàng mới, bạn phải thay đổi bảng và sửa đổi NHÓM CHỦ ĐỀ cho phù hợp.

Phân vùng hàng tháng sẽ được Oracle tạo tự động bất cứ khi nào các giá trị mới được chèn hoặc cập nhật.




  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. ORA-00907:thiếu dấu ngoặc đơn bên phải (Có Ví dụ)

  2. CHR (0) trong REGEXP_LIKE

  3. Oracle:Từ khóa YEAR không hợp lệ

  4. So sánh các giá trị được phân tách bằng dấu phẩy từ hai cột của hai bảng khác nhau

  5. ÍT HƠN HOẶC BẰNG NHAU TRONG Oracle SQL