前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Oracle逻辑迁移某业务用户及数据

Oracle逻辑迁移某业务用户及数据

作者头像
Alfred Zhao
发布2019-05-24 20:22:59
7630
发布2019-05-24 20:22:59
举报
  • 1.确定基本信息
  • 2.源数据库导出
  • 3.目的数据库导入
  • 4.逻辑迁移注意事项

1.确定基本信息

确定基本信息:

代码语言:javascript
复制
源数据库所在系统类型:________
源数据库地址:__.__.__.__
源数据库版本:________
数据库高可用/灾备:{单机|RHCS|RAC|DataGuard|其他}
迁移导出业务用户:________

目的数据库所在系统类型:________
目的数据库地址:__.__.__.__
目的数据库版本:________
数据库高可用/灾备:{单机|RHCS|RAC|DataGuard|其他}
迁移导入业务用户:________

按上面模板填好必要信息,示例如下:

代码语言:javascript
复制
源数据库所在系统类型:RHEL 6.4
源数据库地址:192.168.XX.XX
源数据库版本:9.2.0.8.0
数据库高可用/灾备:单机
迁移导出业务用户:jingyu

目的数据库所在系统类型:RHEL 6.4
目的数据库地址:192.168.XX.XX
目的数据库版本:11.2.0.4.0
数据库高可用/灾备:RAC
迁移导入业务用户:jingyu

2.源数据库导出

2.1 业务用户相关信息

代码语言:javascript
复制
--用户默认数据表空间,临时表空间
select * from dba_users where username='JINGYU';
--连接到业务用户
conn jingyu/jingyu
--用户角色权限
select * from user_role_privs;
--用户总的对象数量
select count(1) from user_objects;
--用户总的表数量
select count(1) from user_tables;

2.2 用户用到的表空间

代码语言:javascript
复制
--连接到业务用户
conn jingyu/jingyu
--用户用到的表空间
select tablespace_name from user_tables union
select tablespace_name from user_tab_partitions union
select tablespace_name from user_indexes union
select tablespace_name from user_ind_partitions;

2.3 查询对应表空间数据文件情况

代码语言:javascript
复制
--数据表空间对应数据文件信息
select FILE_ID, FILE_NAME, TABLESPACE_NAME, BYTES/1024/1024 "MB", MAXBYTES/1024/1024/1024 "GB", AUTOEXTENSIBLE, STATUS from dba_data_files where TABLESPACE_NAME in ('SYSTEM', 'USERS', 'DBS_D_JINGYU', 'DBS_I_JINGYU');
--数据表空间对应数据文件按表空间分组统计总大小
select TABLESPACE_NAME, sum(BYTES/1024/1024) "MB" from dba_data_files where TABLESPACE_NAME in ('SYSTEM', 'USERS', 'DBS_D_JINGYU', 'DBS_I_JINGYU') group by TABLESPACE_NAME;
--临时表空间对应临时文件信息
select FILE_ID, FILE_NAME, TABLESPACE_NAME, BYTES/1024/1024 "MB", MAXBYTES/1024/1024/1024 "GB", AUTOEXTENSIBLE, STATUS from dba_temp_files where TABLESPACE_NAME='TEMP_JINGYU';
--临时表空间对应临时文件统计总大小
select sum(BYTES/1024/1024) "MB" from dba_temp_files where TABLESPACE_NAME='TEMP_JINGYU';

2.4 选择合适的导出方案

代码语言:javascript
复制
--导出方案exp示例(10g之前版本使用)
nohup exp jingyu/jingyu OWNER=jingyu BUFFER=10240000 STATISTICS=none RESUMABLE=y FILE=jingyu_exp.dmp LOG=jingyu_exp.log &

--导出方案expdp示例(10g及以后版本建议使用数据泵expdp)
nohup expdp system directory=jy schemas=jingyu dumpfile=jingyu_all%U.dmp logfile=jingyu_all.log parallel=2 &

有关expdp详细内容可参考:

3.目的数据库导入

3.1 目的数据库当前相关信息

代码语言:javascript
复制
--确定目的数据库基本信息
select instance_name, status from v$instance;
select dbid, open_mode from v$database;
--确定ASM磁盘组剩余空间
select GROUP_NUMBER, NAME, TYPE, TOTAL_MB, FREE_MB, USABLE_FILE_MB from v$asm_diskgroup;
--如果是文件系统管理,直接df -g查看数据文件存放目录的空间
--确定已有表空间数据文件情况
select FILE_ID, FILE_NAME, TABLESPACE_NAME, BYTES/1024/1024 "MB", MAXBYTES/1024/1024/1024 "GB", AUTOEXTENSIBLE, STATUS from dba_data_files where TABLESPACE_NAME in ('SYSTEM', 'USERS', 'DBS_D_JINGYU', 'DBS_I_JINGYU');

3.2 导入前准备

代码语言:javascript
复制
--1. 创建新表空间
create tablespace DBS_D_JINGYU datafile '+DATA01';
create temporary tablespace TEMP_JINGYU tempfile '+DATA01';
--此步骤还需要确定是否需要创建其他表空间,确定是否需要建多个数据文件
--2. 创建用户
create user jingyu identified by jingyu TEMPORARY TABLESPACE TEMP_JINGYU default tablespace DBS_D_JINGYU;
--3. 赋予用户权限
grant resource, connect, dba to jingyu;

3.3 导入方案

代码语言:javascript
复制
--导入方案的选择由之前导出方案决定:exp/imp,expdp/impdp。
--导入方案imp示例
nohup imp jingyu/jingyu BUFFER=10240000 RESUMABLE=y FILE=jingyu_exp.dmp LOG=imp_jingyu_exp.log IGNORE=y FULL=y &

--导入方案impdp示例
nohup impdp system directory=jy schemas=jingyu table_exists_action=replace dumpfile=jingyu_all%U.dmp logfile=impdp_jingyu_all.log parallel=2 &

有关impdp详细内容可参考:

4.逻辑迁移注意事项

4.1 如果需要保证业务数据前后一致性

那么在导出开始前,需要停止源数据库业务,直到成功导入到目标数据库时,应用修改新的连接方式完毕,才可以再次启动业务;

4.2 如果之前表空间管理不规范

早期imp导入工具还没有显示指定重定向表空间的功能,建议整改后迁移;后来impdp才引入重定向表空间的功能,导入时直接使用REMAP_TABLESPACE参数。

对于更复杂的逻辑迁移场景可参考:

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2015-12-09 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 1.确定基本信息
  • 2.源数据库导出
    • 2.1 业务用户相关信息
      • 2.2 用户用到的表空间
        • 2.3 查询对应表空间数据文件情况
          • 2.4 选择合适的导出方案
          • 3.目的数据库导入
            • 3.1 目的数据库当前相关信息
              • 3.2 导入前准备
                • 3.3 导入方案
                • 4.逻辑迁移注意事项
                相关产品与服务
                数据库
                云数据库为企业提供了完善的关系型数据库、非关系型数据库、分析型数据库和数据库生态工具。您可以通过产品选择和组合搭建,轻松实现高可靠、高可用性、高性能等数据库需求。云数据库服务也可大幅减少您的运维工作量,更专注于业务发展,让企业一站式享受数据上云及分布式架构的技术红利!
                领券
                问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档