| Oracle FAQ | Your Portal to the Oracle Knowledge Grid | |
|  |  | |||
Home -> Community -> Mailing Lists -> Oracle-L -> Re: How to move tables from one tablespace to another (Oracle 7.3.4)
This is a multi-part message in MIME format.
------=_NextPart_000_0132_01BFB30C.0C1A68A0 Content-Type: text/plain;
        charset="iso-8859-1"
Content-Transfer-Encoding: quoted-printable
I have posted this one before, but why not one more time. I can't claim = this script, it is from the very Mr. Thomas Kyte.
I'll give you the Oracle8.0 and before answer as well as the Oracle8i =
and above answer (in 8i, this is *trivial*, in 8.0 and before, it takes =
practice and time)....
 =20
 you don't move procedures -- they are compiled into system and will =
remain there forever.  you can move tables and indexes mostly (there are =
other things but this
 covers most of it)...
 =20
 There are 2 methods we can use to do this.  One is to use a combination =
of "alter table X move tablespace Y" and "alter index X rebuild =
tablespace Y"  -- this works in
 Oracle8i release 8.1 and up ONLY.  Attached is a script called =
moveall.sql.  It uses the user_segments table to generate all of the =
needed "alter table move" and "alter
 index rebuild" statements to move a table/index into another tablespace =
preserving the storage characteristics currently assigned to the object. =
 For example, when we
 run moveall.sql in the SCOTT schema, we might see:
 =20
 scott_at_ORACLE> @moveall
 scott_at_ORACLE> set echo off
 =20
 alter TABLE ACCOUNT move
 tablespace users
 storage ( initial 10240 next 10240
 minextents 1 maxextents 121
 pctincrease 50 freelists 1);
 =20
 alter TABLE BONUS move
 tablespace users
 storage ( initial 10240 next 10240
 minextents 1 maxextents 121
 pctincrease 50 freelists 1);
 =20
 alter TABLE DEPT move
 tablespace users
 storage ( initial 10240 next 10240
 minextents 1 maxextents 121
 pctincrease 50 freelists 1);
 =20
 alter INDEX PK_DEPT rebuild
 tablespace users
 storage ( initial 10240 next 10240
 minextents 1 maxextents 121
 pctincrease 50 freelists 1);
 =20
 ....
 =20
 It begins by moving a table and then rebuilding each of the indexes on =
that table.  Since the indexes on the tables being moved will become =
unusable after the table, this
 script rebuilds them right after moving a table -- before moving the =
next table (to reduce downtime).
 =20
 Running the moveall.sql script is harmless as it is written.  It =
generates the SQL you need to run and saves the sql into yet another =
script file "tmp.sql". You should edit
 tmp.sql, review it, modify it if you want (eg: if you have a multi-cpu =
system, you could modify the index rebuilds to be "parallel N", =
"unrecoverable" and add other options
 to make them go faster on your system), and then run it.
 =20
------=_NextPart_000_0132_01BFB30C.0C1A68A0 Content-Type: text/html;
        charset="iso-8859-1"
Content-Transfer-Encoding: quoted-printable
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN"> <HTML><HEAD> <META content=3D"text/html; charset=3Diso-8859-1" =http-equiv=3DContent-Type>
<META content=3D"MSHTML 5.00.2919.6307" name=3DGENERATOR> <STYLE></STYLE> </HEAD> <BODY> <DIV><FONT face=3DArial size=3D2>I have posted this one before, but why =not one more=20
system), and then run it.<BR>  <BR> --------------------- =moveall.sql=20
------------------------------------ set echo off<BR>  =<BR> column=20
segment_type, 'TABLE', segment_name, table_name )=20
order_col1,       decode( segment_type, =
'TABLE',=20
1, 2 ) order_col2,<BR>       'alter ' ||=20
segment_type || ' ' || segment_name =
||<BR>      =20
decode( segment_type, 'TABLE', ' move ', ' rebuild ' ) || chr(10)=20
||       ' tablespace &1 ' || chr(10)=20
||<BR>       ' storage ( initial ' ||=20
initial_extent || ' next ' || next_extent || chr(10)=20
||<BR>       ' minextents ' || min_extents =
|| '=20
maxextents ' || max_extents || chr(10)=20
<BR> ||<BR>       ' pctincrease ' ||=20
pct_increase || ' freelists ' || freelists || ');'   from=20
user_segments, (select table_name, index_name from user_indexes ) where=20
segment_type in (<BR> 'TABLE', 'INDEX' )<BR>   and =
segment_name =3D=20
index_name (+)<BR> order by 1, 2<BR> /<BR>  =
<BR> spool=20
off<BR>  <BR> set heading on<BR> set verify =
on<BR> set=20
feedback on<BR> set echo=20
on<BR> -------------------------------------------------------------=-----=20
|  |  |