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
![]() |
![]() |