oracle数据库迁移步骤思路
admin
2023-06-05 20:41:36
0

背景做为一名DBA,oracle数据库迁移是经常要遇到的事情,正好最近我也在迁移一个业务系统,数据库就是oracle,顺便记录一下。

说明为了方便说明,旧的数据库称为A,新的为B。用户和密码是IRP/IRP ,  B是全新的环境。

 

步骤思路 

1.从 A 上导出数据文件。

sqlplus /nolog
conn / as sysdba
EXP IRP/IRP BUFFER=64000 FILE=D:\test.DMP log=D:\test.log OWNER=IRP

 

2.在A机器上查看用户默认表空间,以便导入时创建一样的表空间oracle数据库迁移步骤思路

SQL> select username,default_tablespace from dba_users where username ='IRP';       
       
USERNAME                       DEFAULT_TABLESPACE       
------------------------------ ------------------------------       
IRP                                     IRP


3.查看用户使用的表空间

SQL> select DISTINCT owner ,tablespace_name from dba_extents where owner like 'IRP';       
       
OWNER                          TABLESPACE_NAME       
------------------------------ ------------------------------       
IRP                                  IRP


4.查看表空间对应的数据文件,以便在B上创建大小合适的数据文件。

SQL> select file_name,tablespace_name from dba_data_files where tablespace_name  in 'IRP';                   
FILE_NAME                                          TABLESPACE_NAME       
------------------------------------------------------------ ----------       
D:\APP\ADMINISTRATOR\ORADATA\ORCL\IRP.DBF      IRP
 
如果用户使用多个表空间,查询语句如下
select file_name,tablespace_name from dba_data_files where tablespace_name  in ('IRP1','IRP2');


5.检查B机器的表空间,看是否存在IRP(如果是新的服务器,不需要这一步)

select name from v$tablespace where name in 'IRP'      
查找不到,说明没有这个两个表空间,需要创建。

 

6.在B上创建表空间、用户并授权

创建大文件表空间
CREATE BIGFILE TABLESPACE "IRP" DATAFILE 'D:\app\oracle\oradata\orcl\irp.dbf' SIZE 100M AUTOEXTEND ON NEXT 100M MAXSIZE UNLIMITED LOGGING EXTENT MANAGEMENT LOCAL SEGMENT SPACE MANAGEMENT AUTO;
 
创建默认表空间
或者 CREATE TABLESPACE "IRP" DATAFILE 'D:\app\oracle\oradata\orcl\irp.dbf' SIZE 100M AUTOEXTEND ON NEXT 100M MAXSIZE 10000M LOGGING EXTENT MANAGEMENT LOCAL;
 
创建用户      
CREATE USER "IRP" PROFILE "DEFAULT" IDENTIFIED BY "IRP" DEFAULT TABLESPACE "IRP" TEMPORARY TABLESPACE "TEMP" ACCOUNT UNLOCK;
 
授权      
GRANT "CONNECT" TO "IRP";       
GRANT "RESOURCE" TO  "IRP";       
GRANT unlimited tablespace TO "IRP";

 

注: BigFile表空间只能创建一个datafile数据文件,SmallFile表空间最多可以创建1024个数据文件

 

7.如果在服务器B上已经存在该用户,怎么样删除该用户.

查看是否存在该用户SQL> select username from dba_users where username='IRP';      
删除用户及其拥有的所有对象
drop user IRP cascade;
 
查看这个用户下面是否有对象;
select object_type,count(*) from all_objects where owner='IRP' group by object_type
 
       OBJECT_TYPE           COUNT(*)
------------------------------------------------------------ ----------
1    SEQUENCE    3      
2    PROCEDURE    5       
3    LOB    139       
4    PACKAGE    3       
5    PACKAGE BODY    2       
6    TRIGGER    1       
7    TABLE    384       
8    INDEX    426       
9    FUNCTION    6

此时如果这个用户在连接,drop会出错,必须先杀掉用户的session,然后再drop user

构建杀掉IRP用户session的语句并执行,
SELECT 'alter system kill session '''||SID||','||SERIAL#||''' immediate;' FROM V$SESSION WHERE USERNAME='IRP';

上面的语句是构建出杀掉IRP用户session的语句,再复制这些语句,粘贴到sqlplus中执行,来杀掉IRP的session。
'ALTERSYSTEMKILLSESSION'''||SID||','||SERIAL#||'''IMMEDIATE;'      
--------------------------------------------------------------
alter system kill session '9,42043' immediate;      
alter system kill session '10,9137' immediate;       
alter system kill session '72,17487' immediate;       
alter system kill session '84,3280' immediate;       
alter system kill session '91,976' immediate;       
alter system kill session '100,13516' immediate;       
alter system kill session '111,5973' immediate;       
alter system kill session '115,4751' immediate;       
alter system kill session '120,10356' immediate;       
alter system kill session '211,4075' immediate;       
alter system kill session '216,48068' immediate;


8.最后在B上导入数据

一定注意执行imp时要退出sqlplus,直接在命令行执行。

IMP test/test BUFFER=64000 FILE=D:\test.DMP log=D:\imptest.log FROMUSER=IRP TOUSER=IRP


相关内容

热门资讯

真实感,AI时代写作的生命力所... AI时代,对于许多人来说,因为有了各种智能工具的加持,写作似乎变得容易了。通过提出命题、投喂内容,无...
一个以科技为名的节日,在一座深... 5月23日,2026年上海科技节在上海科技馆正式开幕,同日还将举办第五届上海科技传播大会,并见证上海...
原创 靠... 谁能想到,一笔眼看能让90后创始人躺赚140亿的AI公司收购案,会被商务部一记重拳紧急喊停。 江西小...
特朗普称美伊协议基本谈成 美东时间23日下午,美国总统特朗普在社交媒体发文,称美国与伊朗已经基本谈成一份协议。(央视记者 刘骁...
以媒:美伊协议或“非常不利”,... 新华社耶路撒冷5月23日电(记者陈君清 庞昕熠)以色列媒体23日报道,以总理内塔尼亚胡当晚召集执政联...
独属于AI时代的故事|新华走笔 来源:5月22日《新华每日电讯》 作者:孙正好 AI浪潮激荡,总会在那些平凡而普通的个体生命中,惊起...
原创 i... 2026年5月20日,iQOO带来了全新旗舰机型iQOO 15T,同时一口气上新iQOO Pad6 ...
巴基斯坦消息人士:美伊接近达成... 新华社伊斯兰堡5月23日电(记者杨恺)巴基斯坦官方消息人士23日告诉新华社记者,美国与伊朗接近达成一...
特朗普又说美伊“越来越接近”达... 新华社华盛顿5月23日电(记者黄强 徐剑梅)美国总统特朗普23日说,美国与伊朗的谈判“越来越接近”达...