发布网友 发布时间:2022-04-09 11:28
共2个回答
懂视网 时间:2022-04-09 15:50
(
PARTITION P1 VALUES LESS THAN (TO_DATE(‘2004-7-1‘, ‘YYYY-MM-DD‘)) TABLESPACE space01,
PARTITION P2 VALUES LESS THAN (TO_DATE(‘2005-1-1‘, ‘YYYY-MM-DD‘)) TABLESPACE space02,
PARTITION P3 VALUES LESS THAN (TO_DATE(‘2005-7-1‘, ‘YYYY-MM-DD‘)) TABLESPACE space03,
PARTITION P4 VALUES LESS THAN (MAXVALUE) TABLESPACE space04
)
AS SELECT ID, TIME FROM temp;
4:重命名表名
RENAME temp TO temp_old;
RENAME temp_new TO temp;
5:查询分区纪录存储情况
SELECT COUNT(1) FROM temp PARTITION (space01);
SELECT COUNT(1) FROM temp PARTITION (space02);
SELECT COUNT(1) FROM temp PARTITION (space03);
SELECT COUNT(1) FROM temp PARTITION (space04);
SELECT COUNT(1) FROM temp_old;
--分区存储纪录数之和与原纪录数相同,跨表空间分区存储成功.
有点:方法简单易用,采用DDL语句,不会产生UNDO,而只会产生少量REDO,效率相对较高,而且建表完成后数据已经分布到各个分区中.
缺点:对于数据库的一致性方面需要额外考虑.无法通过手工锁表的方式保证一致性.
适用于修改不频繁的表,在空闲时进行操作,表的数据量不宜太大.
oracle的表如何跨表空间存储
标签:分区表 partition by range
热心网友 时间:2022-04-09 12:58
尽量把表和索引的表空间存储在不同在磁盘上,把两类不同IO性质的数据分开放,这样可以提高磁盘的IO总体性能;