oracle的表如何跨表空间存储

oracle的一个表所在表空间,空间已经占满,其他表空间有剩余空间.实现表存在另外的表空间.

方案一:利用原表重建分区表

1:原表temp,存在字段id,time;

2:temp存在纪录;

3:根据原表temp创建新的分区表temp_new

CREATE TABLE temp_new (ID, TIME) PARTITION BY RANGE (TIME)

(

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,效率相对较高,而且建表完成后数据已经分布到各个分区中.

缺点:对于数据库的一致性方面需要额外考虑.无法通过手工锁表的方式保证一致性.

适用于修改不频繁的表,在空闲时进行操作,表的数据量不宜太大.

时间: 2024-10-15 20:13:10

oracle的表如何跨表空间存储的相关文章

oracle 修改表空间存储路径

[[email protected] ~]# more /etc/oracle-releaseOracle Linux Server release 5.7 Oracle Database 11g Enterprise Edition Release 11.2.0.3.0 - 64bit ProductionPL/SQL Release 11.2.0.3.0 - ProductionCORE 11.2.0.3.0 ProductionTNS for Linux: Version 11.2.0.3

【转】Oracle - 数据库的实例、表空间、用户、表之间关系

[转]Oracle - 数据库的实例.表空间.用户.表之间关系 完整的Oracle数据库通常由两部分组成:Oracle数据库和数据库实例. 1) 数据库是一系列物理文件的集合(数据文件,控制文件,联机日志,参数文件等): 2) Oracle数据库实例则是一组Oracle后台进程/线程以及在服务器分配的共享内存区. 在启动Oracle数据库服务器时,实际上是在服务器的内存中创建一个Oracle实例(即在服务器内存中分配共享内存并创建相关的后台内存),然后由这个Oracle数据库实例来访问和控制磁盘

Oracle - 数据库的实例、表空间、用户、表之间关系

完整的Oracle数据库通常由两部分组成:Oracle数据库和数据库实例. 1) 数据库是一系列物理文件的集合(数据文件,控制文件,联机日志,参数文件等): 2) Oracle数据库实例则是一组Oracle后台进程/线程以及在服务器分配的共享内存区. 在启动Oracle数据库服务器时,实际上是在服务器的内存中创建一个Oracle实例(即在服务器内存中分配共享内存并创建相关的后台内存),然后由这个Oracle数据库实例来访问和控制磁盘中的数据文件.Oracle有一个很大的内存快,成为全局区(SGA

不同类型的数据跨表空间迁移的解决办法

http://blog.csdn.net/passion_wang/article/details/6541369 Oracle10g数据跨表空间迁移 因某些开发人员由于对oracle数据库理解的不够深入,往往在建表的时候指定了当前用户非默认的表空间,这样就导致了在exp及imp等操作时候问题很多,因此需要将这些表及相关的数据迁移回当前用户的默认表空间里.Oracle10g数据数据库提供了一个Move命令可以把这样的数据对象进行跨表空间的迁移,也可以对含有BLOB.CLOB这样的二进制大字段的表

oracle 查看用户所在的表空间

查看当前用户的缺省表空间 SQL>select username,default_tablespace from user_users; 查看当前用户的角色 SQL>select * from user_role_privs; 查看当前用户的系统权限和表级权限 SQL>select * from user_sys_privs; SQL>select * from user_tab_privs; 查看用户下所有的表 SQL>select * from user_tables;

ORACLE 数据库、实例、表空间、用户、数据库对象

Oracle是一种数据库管理系统,是一种关系型的数据库管理系统.通常情况了我们称的"数据库",包含了物理数据.数据库管理系统.内存.操作系统进程的组合体,就是指这里所说的数据库管理系统. 完整的Oracle数据库通常由两部分组成:Oracle数据库和数据库实例. ① Oracle数据库是一系列物理文件的集合: 组成Oracle数据库的文件可以分成三个类型:数据文件(data file).重做日志文件(redo log file)和控制文件(control file).数据文件保存数据,

ORACLE 查看当前用户信息(用户,表视图,索引,表空间,同义词,存储过程,约束条件)

1.用户 查看当前用户的缺省表空间 SQL>select username,default_tablespace from user_users; 查看当前用户的角色 SQL>select * from user_role_privs; 查看当前用户的系统权限和表级权限 SQL>select * from user_sys_privs; SQL>select * from user_tab_privs; 显示当前会话所具有的权限 SQL>select * from sessi

【oracle11g,18】存储结构:暂时表,手工条带化,表/索引迁移表空间,删除表,外部表

一. 暂时表 暂时表放在暂时表空间,不生成redo,仅仅有undo. 在暂时表中能够创建索引.视图及触发器,还能够使用"Export and Import(导出和导入)"或"Data Pump(数据泵)"导出和导入暂时表的定义.可是.即使使用了ROWS 选项,也不会导出数据. 有基于事务(默认)和基于session两种.其它的会话不能訪问到. 在暂时表中.DML锁永远不须要. 1.创建默认的(基于事务的)暂时表:(on commit delete rows:提交时清

oracle 查询表的大小,表空间的使用情况,默认表空间

oracle 查询表的大小,表空间的使用情况,默认表空间 oracle 查询表的大小,表空间的使用情况,默认表空间 --查看某张表占用磁盘空间大小 ( 表名大写 ) Select Segment_Name,Sum(bytes)/1024/1024 From User_Extents Group By Segment_Name having Segment_Name='表名'; 查看用户默认表空是那个 select username,default_tablespace from dba_user