广告
返回顶部
首页 > 资讯 > 数据库 >ORACLE修改表空间方法
  • 692
分享到

ORACLE修改表空间方法

ORACLE修改表空间方法数据库入门数据库基础教程 2015-03-19 14:03:49 692人浏览 猪猪侠
摘要

ZT:https://www.cnblogs.com/guohu/p/4500638.html   一、使用imp/exp。先导出源库,再创建新库把表空间创建好,然后再导入。(据说这样可以,前提是新的库里面不能有与源库相同名字的表空间。有待

ORACLE修改表空间方法[数据库教程]

ZT:https://www.cnblogs.com/guohu/p/4500638.html

 

一、使用imp/exp。先导出源库,再创建新库把表空间创建好,然后再导入。(据说这样可以,前提是新的库里面不能有与源库相同名字的表空间。有待验证!) 

二、使用脚本进行修改。据目前所了解,正长情况下需要修改表的空间表的索引的空间,如果涉及到BOLB字段的表,修改的方式又不一样了! 
正常情况下的修改脚本: 
1.修改表的空间 
alter table TABLE_NAME move tablespace TABLESPACENAME 

查询当前用户下的所有表 
select ‘alter table  ‘|| table_name ||‘  move tablespace tablespacename;‘  from user_all_tables; 

2.修改表的索引的空间 
alter index INDEX_NAME rebuild tablespace TABLESPACENAME 

查询当前用户下的所有索引 
select ‘alter index ‘|| index_name ||‘ rebuild tablespace tablespacename;‘ from user_indexes; 

可以使用脚本执行查询的结果,这样就可以批量处理! 

不正常情况即含有BLOB字段的表: 
参考下面的文档 

本人已经执行过,是可行的,但是不知道有没有漏掉数据库中其它对象。是否还存在有对象的表空间需要修改,需要进一步发现或有数据库高手帮忙讲解则不胜感激!目前的修改在项目中还没有出现问题! 

在移植看注意研究了下oracle ALTER TABLE MOVE 的语法: 

       ALTER TABLE table_name MOVE [ONLINE] tablespace_name; 
通过上面的语句可以移植表到新表空间, 

如果要移植LOB字典需要参考以下语法: 
ALTER TABLE table_name LOB (lob_item) STORE AS [lob_segment] 
      ( 
        TABLESPACE tablespace_name 
                   (STORAGE.....) 
           ENABLE|DISABLE STORAGE IN ROW 
           CHUNK integer 
           PCTVERSioN integer 
            RETENTION 
            FREEPOOLS integer 
            CACHE|NOCACHE|CACHE READS 
           INDEX lobindexname 

(TABLESPACE tablesapce_name 

((STORAGE.....)) 


.... 

注解: 

LOB (lob_item):表中的lob字段 
STORE AS [lob_segment]:每个lob字段在表创建后系统都会自动单独创建一个段,可以通过这个参数手动指定一个段名 
   tablespace_name:LOB字段新的存储表空间 
(STORAGE.....):指定tablespace_name的存储属性 
    ENABLE STORAGE IN ROW:如果设置了enable storage in row 那么oracle会自动将小于4000bytes的数据存储在行内, 这是ORACLE的默认值,对于大于4000字节的lob字段保存在lob段(同disable storage in row),在表段将保留36-84字节的控制信息。对于disable storage in row,Oracle将lob字段分开保存在lob段中,而仅仅在行位置保留20字节的指针。对于相当于disable storage in row的这部分(也就是单独保存在LOB段的这部分数据),UNDO仅仅是记录指针与相关lob索引改变,如果发生更新操作等DML操作,原始数据将保留在LOB段。 

    DISABLE STORAGE IN ROW:如果DISABLE这个属性,那么lob数据会在行外存储,行内只存储该lob值得指针,而且这个属性在表 
创建后只能在MOVE表时才可以被改变 
    CHUNK:是一个很特别的属性,对一次LOB数据的操作(插入或更新),因该分配多少存储空间,指定的值最好是数据库块的倍数,而且指定的值不能大于表空间区间中NEXT的值, 要不然ORACLE会return一个错误,如果以前已经设置这个值了,那么在后期指定的值是不能被改变的。 

storage as ( CHUNK bytes )表示对于disable storage in row的这部分,最小的LOB块的大小,必须是数据库块(DB_BLOCK_SIZE)的整数倍。一个chunk最多只保留一行LOB数据,也就是说,如果你设置了32K的CHUNK,但是如果LOB字段大小只有4K,也将占用32K的空间 

storage as(cache|nocahce)表示是否允许lob段经过buffer cache并缓存。默认是nocache,表示直接读与直接写,不经过数据库的data buffer。所以,默认情况下,对于单独保存在LOB段的这部分数据,在发生物理读的时候,是直接读,如direct path read (lob) 

storage as(nocache logging |nocache nologging),logging/nologging属性只对nocache方式生效,默认是logging,如果是nologging方式,对于 保存在行外的log部分,在update等DML操作时将不记录redo日志。 

    PCTVERSION integer、RETENTION:都是ORACLE用来管理LOB字段镜像数据的。在LOB 数据的更新过程中, 
ORACLE没有用UNDO TABLESPACE空间,而是从LOB字段所在的表空间里划分一段空间来做镜像空间的, 
这个空间的大小由PCTVERSION参数控制,默认值为10,代表划分表空间的10%作为镜像空间, 
每个镜像空间的单元大小由CHUNK参数指定,pctversion可以使用在manual undo mode和automatic undo mode 环境中. 
retention应用了automatic undo mode中的undo_retention通过时间来管理lob镜像空间. 
pctversion和retention不能同时被指定.建议数据库在automatic undo mode下使用retention参数。 
FREEPOOLS integer:给LOG segment指定free list.RAC环境下integer为实例的个数.单实例环境下为1.在automatic undo mode下oracle默认采用 
FREEPOOLS来管理空闲块列表。除非我们在表的storage配置中指定了freelist groups参数. 
CACHE|NOCACHE|CACHE READS:指定lob块是否在database buffer中缓存. 
INDEX lobindexname (TABLESPACE tablesapce_name ((STORAGE.....):给lob列指定索引存储参数 
举例: 
SQL> show parameter db_create_file_dest 

SQL> create tablespace test datafile size 100M autoextend off; 
SQL> create table test(a varchar2(100), b clob, d blob) pctfree 10 tablespace test; 

SQL> desc test 
SQL> SELECT segment_name,tablespace_name,segment_type FROM dba_segments WHERE tablespace_name=‘TEST‘; 

我们发现每个LOB字段单独有一个LOGSEGMENT和LOBINDEX; 

SQL> set linesize 200 
col table_name fORMat a5 
col column_name format a5 
SELECT b.table_name, 
a.segment_name, 
b.index_name, 
a.segment_type, 
b.column_name, 
a.tablespace_name, 
b.chunk, 
b.cache, 
b.freepools, 
b.pctversion, 
b.retention 
FROM dba_segments a,dba_lobs b 
WHERE a.segment_name = b.segment_name 
AND a.tablespace_name = ‘TEST‘ 


SQL> 

从上面的结果我们可以观察到LOB字段的各个属性. 
下面我们对LOB字段move到另一个表空间 

SQL> create tablespace lob_test datafile size 100M autoextend off; 

SQL> ALTER TABLE TEST MOVE LOB(B) STORE AS TEST_B ( 
TABLESPACE lob_test 
DISABLE STORAGE IN ROW 
CHUNK 16384 
RETENTION 
FREEPOOLS 1 
NOCACHE); 
SQL> ALTER TABLE TEST MOVE LOB(D) STORE AS TEST_D ( 
TABLESPACE lob_test 
DISABLE STORAGE IN ROW 
CHUNK 16384 
RETENTION 
FREEPOOLS 1 
NOCACHE); 
SQL> SELECT segment_name,tablespace_name,segment_type FROM dba_segments WHERE tablespace_name=‘TEST‘; 

SQL> set linesize 200 
col table_name format a5 
col column_name format a5 
SELECT b.table_name, 
a.segment_name, 
b.index_name, 
a.segment_type, 
b.column_name, 
a.tablespace_name, 
b.chunk, 
b.cache, 
b.freepools, 
b.pctversion, 
b.retention 
FROM dba_segments a,dba_lobs b 
WHERE a.segment_name = b.segment_name 
AND a.tablespace_name = ‘LOB_TEST‘ 
/SQL> 

在一些复杂情况下可能需要连表一起移植 
alter table table_name move [tablespace_name] lob (lob_item) store as [lobsegmentname] (tablespace tablespace_name.....); 
移植分区中lob 
alter table table_name move partition [partition_name] lob (lob_item) store as [logsegmentname] (tablespace_name.....); 
移植分区表 
alter table table_name move partition [partition_name] tablespace_name lob (lob_item) store as [logsegmentname] (tablespace_name.....); 
如果不需要修改lobsegmentname,可以同时移植多个列 
alter table table_name move lob (lob_item1,lob_item2,lob_item3...) store as [lobsegmentname] (tablespace tablespace_name.....); 



    LOB段也可以利用move来重整数据,以下的语句会将表与lob字段move到指定的表空间: 

   alter table table_name move [tablespace tbs_name] 

lob(lob_field1,lob_field2) store as (tablespace new_tbs_name); 

如果LOB字段在分区表中,则增加partition关键字,如 

   alter table table_name move [partition partname] [tablespace tbs_name] 

lob(field) store as (tablespace new_tbs_name); 



在数据库中合理的存储LOB列,不仅可以提升性能,而且还可以有效的管理存储空间.

ORACLE修改表空间方法

原文:Https://www.cnblogs.com/Nina-piaoye/p/13298486.html

您可能感兴趣的文档:

--结束END--

本文标题: ORACLE修改表空间方法

本文链接: https://www.lsjlt.com/news/7152.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • ORACLE修改表空间方法
    ZT:https://www.cnblogs.com/guohu/p/4500638.html   一、使用imp/exp。先导出源库,再创建新库把表空间创建好,然后再导入。(据说这样可以,前提是新的库里面不能有与源库相同名字的表空间。有待...
    99+
    2015-03-19
    ORACLE修改表空间方法 数据库入门 数据库基础教程
  • oracle怎么修改表空间大小
    要修改Oracle表空间大小,可以按照以下步骤操作:1. 登录到Oracle数据库的系统用户,例如sys用户。2. 使用ALTER ...
    99+
    2023-08-30
    oracle
  • Oracle查看表空间大小以及修改表空间大小
    Oracle查看表空间大小以及修改表空间大小问题描述:  1.修改表空间大小  2.查看表空间大小及相关的sql。一.修改表空间大小解决以上问题的办法:通过增大表空间即可解决,如下:使用...
    99+
    2022-10-18
  • Oracle怎么查看和修改临时表空间
    这篇文章主要讲解了“Oracle怎么查看和修改临时表空间”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Oracle怎么查看和修改临时表空间”吧!--查表空间...
    99+
    2022-10-18
  • plsql修改表空间自动扩展的方法是什么
    在PL/SQL中,可以使用ALTER TABLESPACE语句来修改表空间的自动扩展属性。具体方法如下:1. 首先,使用ALTER ...
    99+
    2023-09-09
    plsql
  • 表空间问题----收缩空间方法:表空间中表的查法:扩展表空间
    收缩空间方法:一.不删除数据,收缩表空间的数据文件大小,释放磁盘空间查询对应表所在的表空间select OWNER,SEGMENT_NAME,TABLESPACE_NAME,BYTES/1024/...
    99+
    2022-10-18
  • oracle 修改表名几种方法
    alter table byp3 rename to byp_2rename byp_2 to byp3 create byp_2 as select * from byp3(...
    99+
    2022-10-18
  • 关于增大oracle表空间的方法
                     &...
    99+
    2022-10-18
  • Oracle表空间收缩方法是什么
    Oracle表空间收缩方法是什么,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。应用背景:某些情况下,由于前期设计上没有考虑全面,导致表空间预建太大,远远超出实际...
    99+
    2023-06-06
  • mysql从共享表空间修改为单个表的表空间存储方式是什么
    本篇文章为大家展示了mysql从共享表空间修改为单个表的表空间存储方式是什么,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。 使用过MySQL的同学,刚开始接触最多...
    99+
    2022-10-19
  • Oracle表空间
    一学三思三敲才能懂,才能长期有效的记忆    起初学习Oracle的时候,已经了解Oracle的优点,比如分布式管理,轻松协调;优越的性能;支持大数据的格式;还有一点...
    99+
    2022-10-18
  • oracle扩展表空间的方法有哪些
    扩展Oracle表空间的方法有以下几种:1. 使用ALTER TABLESPACE命令:使用ALTER TABLESPACE命令可以...
    99+
    2023-09-15
    oracle
  • Oracle Temp表空间切换方法是什么
    这篇文章主要介绍“Oracle Temp表空间切换方法是什么”,在日常操作中,相信很多人在Oracle Temp表空间切换方法是什么问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解...
    99+
    2022-10-18
  • Oracle 中检查临时表空间的方法
    目录一、什么是临时表空间二、oracle创建临时表空间的方法三、如何在 Oracle 中检查临时表空间3.1 如何检查 Temp 表空间的大小3.2 oracle如何查看临时表空间的可用空间3.3 如何在实例级别检查临时...
    99+
    2022-10-19
  • Oracle中检查临时表空间的方法
    目录一、什么是临时表空间二、oracle创建临时表空间的方法三、如何在 Oracle 中检查临时表空间3.1 如何检查 Temp 表空间的大小3.2 oracle如何查看临时表空间的...
    99+
    2022-11-13
    Oracle 临时表空间 Oracle 检查临时表空间
  • oracle丢失temp表空间的处理方法
    之前有做临时表空间的切换,切换后没drop tablespace就删除了temp01.dbf结果排序跟查dba_temp_files报错 SQL> select tablespace_name,file_...
    99+
    2023-05-01
    oracle丢失temp表空间
  • oracle清理表空间的方法是什么
    Oracle清理表空间的方法有以下几种:1. 通过删除不再使用的表和索引来释放表空间空间。可以使用DROP TABLE和DROP I...
    99+
    2023-09-29
    oracle
  • 数据库中如何修改表的表空间
    这篇文章主要介绍了数据库中如何修改表的表空间,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。修改表空间后,需要重新生成索引1、查询表空间sel...
    99+
    2022-10-18
  • oracle之表空间
    1、创建表空间sqlplus / as sysdba //以dba的身份进库startup //开启数据库create tablespace db_work //创建名为db_work的表空间d...
    99+
    2022-10-18
  • oracle undo表空间释放的方法是什么
    Oracle中释放undo表空间的方法有以下几种: 使用回滚段管理器(Rollback Segment Management)进...
    99+
    2023-10-26
    oracle
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作