生产环境下,oracle不同用户间的数据迁移。第三部分

任务名称:生产环境下schema ELON数据迁移至schema TIAN
########################################
前期准备:
1:确认ELON用户下的对象状态
select owner,constraint_name,constraint_type,table_name,status,validated from dba_constraints where owner=‘ELON‘
owner constraint_name constraint_type table_name status validated
ELON FK_DUDECT_RESULT_AGREEMENT_ID R T_DUDECT_RESULT DISABLED NOT VALIDATED

有一个外键约束状态为DISABLED NOT VALIDATED

2:确认两个用户的对象有无重名
SQL>select distinct(object_type) from dba_objects where owner=‘ELON‘;
SEQUENCE
TRIGGER
TABLE
INDEX
SQL>select count(*) from dba_objects where owner=‘ELON‘;
56
SQL>select count(*) from dba_objects where owner=‘TIAN‘;
283

[[email protected] ~]$ diff TIAN_object.txt ELON_object.txt
或者:select count(*) from dba_objects where owner=‘ELON‘ and object_name not in (select object_name from dba_objects where owner=‘TIAN‘);
56
结论:无重名对象

3:确定两个用户的约束有无重名
SQL>select count(*) from dba_constraints where owner=‘TIAN‘;
1441
SQL>select count(*) from dba_constraints where owner=‘ELON‘;
179
[[email protected] ~]$ sqlplus / as sysdba <TIAN_con.sql
[[email protected] ~]$ diff TIAN_con1.txt ELON_con1.txt > diff.txt
也可以这样排查:
SQL>select count(*) from dba_constraints where owner=‘ELON‘ and constraint_name not in (select constraint_name from dba_constraints where owner=‘TIAN‘);
179
结论:无重名的约束

4:确定ELON默认数据表空间、临时表空间、索引表空间
SQL>select username,default_tablespace,temporary_tablespace from dba_users where username = ‘ELON‘;
ELON ELON_DATA01 ELON_TEMP
SQL>select username,default_tablespace,temporary_tablespace from dba_users where username = ‘TIAN‘;
TIAN TIAN_DATA01 TIAN_TEMP
SQL>select owner,index_name,tablespace_name from dba_indexes where owner=‘ELON‘;
ELON IDX_REQ_DATE ELON_DATA01
ELON FK_ID ELON_DATA01
ELON IDX_T_DU_RES ELON_DATA01
ELON PK_T_TEMP ELON_IDX01
ELON PK_T_SYS_EXCEPTION ELON_IDX01
ELON PK_T_MESSAGE ELON_IDX01

5:确定dump目录及目录大小
SQL> select * from dba_directories;
OWNER DIRECTORY_NAME DIRECTORY_PATH ORIGIN_CON_ID
---------- ------------------------- -------------------------------------------------- -------------
SYS EXPDP_DIR /data/backup

6:停服务,确保无新数据写入:

7:数据泵导出ELON数据和备份TIAN数据:

7.1数据泵导出ELON数据和备份TIAN数据

expdp system/xxxxxx SCHEMAS=ELON directory=EXPDP_DIR dumpfile =ELON_`date +"%Y%m%d%H%M%S"`.dmp logfile=ELON_`date +"%Y%m%d%H%M%S"`_exp.log

expdp system/xxxxxx SCHEMAS=TIAN directory=EXPDP_DIR dumpfile =TIAN_`date +"%Y%m%d%H%M%S"`.dmp logfile=TIAN_`date +"%Y%m%d%H%M%S"`_exp.log

7.2向TIAN的schema,利用数据泵导入ELON数据:

1)向TIAN导入数据前,查询表空间利用情况:
SQL> select df.tablespace_name ,totalspace total_size, (totalspace-freespace) used_size,freespace avail_size ,round((1-freespace/totalspace)*100) as used_ratio
2 from (select tablespace_name,round(sum(bytes)/1024/1024) totalspace
from dba_data_files group by tablespace_name) df,(select tablespace_name,round(sum(bytes)/1024/1024) freespace
4 from dba_free_space group by tablespace_name) fs where df.tablespace_name=fs.tablespace_name;
TABLESPACE_NAME TOTAL_SIZE USED_SIZE AVAIL_SIZE USED_RATIO
------------------------------ ---------- ---------- ---------- ----------
TIAN_DATA01 20480 8087 12393 39
ELON_IDX01 10240 88 10152 1
SYSAUX 3072 1739 1333 57
UNDOTBS1 83910 8225 75685 10
ELON_DATA01 20480 1979 18501 10
TIAN_IDX01 10240 3591 6649 35
USERS 1024 2 1022 0
SYSTEM 2048 845 1203 41

11 rows selected.
SQL> select a.use_sp 表空间,
round((use_size + free_size),4) || ‘G‘ 总空间,
round(use_size,4) || ‘G‘ 已使用,
round(free_size,4) || ‘G‘ 可用,
round(free_size / (use_size + free_size),4) * 100 || ‘%‘ 可用百分比
from (select/*+rule(a)+*/ tablespace_name use_sp,
sum(bytes) / 1024 / 1024 / 1024 use_size
from dba_segments
group by tablespace_name) a,
(select tablespace_name use_sp,
sum(bytes) / 1024 / 1024 / 1024 free_size
from dba_free_space
group by tablespace_name) b
where a.use_sp = b.use_sp;

表空间 总空间 已使用 可用 可用百分比
--------------- ---------- --------------- --------------- --------------------
TIAN_DATA01 20.0723G 7.9698G 12.1025G 60.29%
TIAN_IDX01 10.0049G 3.5115G 6.4934G 64.9%
ELON_DATA01 19.998G 1.9305G 18.0676G 90.35%
ELON_IDX01 9.999G .0852G 9.9138G 99.15%
SYSAUX 3.0801G 1.7782G 1.3019G 42.27%
SYSTEM 1.999G .8244G 1.1746G 58.76%
UNDOTBS1 81.9404G 8.0297G 73.9107G 90.2%
USERS .999G .0007G .9984G 99.93%
10 rows selected.

2)导入数据
[[email protected] ~]$impdp system/xxxxxx directory=EXPDP_DIR dumpfile=ELON_20180412224710.dmp logfile=TIAN_`date +"%Y%m%d%H%M%S"`_impdp.log remap_schema=ELON:TIAN remap_tablespace=ELON_DATA01:TIAN_DATA01,ELON_IDX01:TIAN_IDX01,ELON_TEMP:TIAN_TEMP TABLE_EXISTS_ACTION=SKIP
2)完成之后,查看表空间利用率,数据增长是否正常
SQL> select a.use_sp 表空间,
round((use_size + free_size),4) || ‘G‘ 总空间,
round(use_size,4) || ‘G‘ 已使用,
round(free_size,4) || ‘G‘ 可用,
round(free_size / (use_size + free_size),4) * 100 || ‘%‘ 可用百分比
group by tablespace_name) b
from (select/*+rule(a)+*/ tablespace_name use_sp,
sum(bytes) / 1024 / 1024 / 1024 use_size
from dba_segments
group by tablespace_name) a,
(select tablespace_name use_sp,
sum(bytes) / 1024 / 1024 / 1024 free_size
from dba_free_space
group by tablespace_name) b
where a.use_sp = b.use_sp;

表空间 总空间 已使用 可用 可用百分比
--------------- ---------- --------------- --------------- --------------------
TIAN_DATA01 20.0723G 9.9618G 10.1105G 50.37%
TIAN_IDX01 10.0049G 3.6025G 6.4023G 63.99%
ELON_DATA01 19.998G 1.9305G 18.0676G 90.35%
ELON_IDX01 9.999G .0852G 9.9138G 99.15%
SYSAUX 3.0801G 1.7806G 1.2996G 42.19%
SYSTEM 1.999G .8244G 1.1746G 58.76%
UNDOTBS1 81.9404G 8.1352G 73.8052G 90.07%
USERS .999G .0007G .9984G 99.93%

10 rows selected.

7.3监控数据泵的工作状态:
SQL> select * from DBA_DATAPUMP_JOBS;
SQL> select * from DBA_DATAPUMP_SESSIONS;
SQL> SELECT OPNAME, TARGET_DESC, SOFAR, TOTALWORK FROM V$SESSION_LONGOPS;
8:验证
迁移之后TIAN总的对象数目
SQL> select count(*) from dba_objects where owner=‘TIAN‘;
339
即:283+56
ELON的对象全部迁移到TIAN
SQL>select count(*) from dba_objects where owner=‘ELON‘ and object_name not in (select object_name from dba_objects where owner=‘TIAN‘);
0
迁移之后TIAN总的约束数目
SQL> select count(*) from dba_constraints where owner=‘TIAN‘;
1620
select count(*) from dba_constraints where owner=‘ELON‘ and constraint_name not in (select constraint_name from dba_constraints where owner=‘TIAN‘);
155

#因为ELON下包含155个非空约束、17个主键约束、7个外键约束;非空约束,系统生成,在导出导入的过程中,约束名发生改变(如SYS_C0017556)
9:回收ELON权限
SQL> select * from dba_sys_privs where grantee=‘ELON‘
ELON CREATE TABLE NO NO
ELON CREATE VIEW NO NO
ELON DEBUG CONNECT SESSION NO NO
ELON DEBUG ANY PROCEDURE NO NO
ELON CREATE DATABASE LINK NO NO
SQL> revoke

原文地址:https://www.cnblogs.com/elontian/p/8819418.html

时间: 2024-11-21 01:44:57

生产环境下,oracle不同用户间的数据迁移。第三部分的相关文章

生产环境下,oracle不同用户间的数据迁移。第二部分

任务名称:生产环境下schema ELON数据迁移至schema TIAN######################################## 测试二:测试参数remap_tablespace 导出schema ELON的全部数据:[[email protected] ~]$expdp system/xxxxxx SCHEMAS=ELON directory=EXPDP_DIR dumpfile =ELON_`date +"%Y%m%d%H%M%S"`.dmp logfil

生产环境下GeoServer如何优化--发布大数据量的影像(大于2g的tiff格式影像)

生产环境下GeoServer如何优化--发布大数据量的影像(大于2g的TIFF格式影像) 前言 Geoserver可以高效的处理数据量小于2GB的TIFF影像,一旦影像的大小超过了2GB,就需要考虑用影像金字塔来替代. 影像金字塔创建多重镶嵌的影像,每个都在不同层级,使得每个切片都存储为一个分离的文件.虽然看起来会增加切片合成的成本,但是却可以加快图像处理速度, 每个预览都是平铺的,因此可以高效的访问子集. 创建金字塔过程 1.准备geotiff格式的影像,下载开源应用程序FWTools 2.打

如何一步一步删除(linux &amp; UNIX)环境下 oracle 11g 集群节点

 Deleting a Cluster Node on Linux and UNIX Systems 1.确定要删除的节点,是否active,pinned $ olsnodes -s -t 如果 pinned ,则crsctl unpin css  -n <nodename>  unpinned 相应的节点 2.禁用相应集群节点的应用资源,进程 先停掉 em: emctl stop dbconsole 以root 用户运行 在要删除节点的 $Grid_home/crs/install 路径

生产环境下ftp的迁移并构建高可用

说明:这是1个小项目就两台DELL的服务器,和一台IP SAN存储(DELL MD3200i).原来是4台小服务器,而且服务器太老了,经常有问题,这回相当于一次ftp的迁移,以前用的是proftp,这次换成了vsftp.数据量有2.5T. 拓扑很简单: 系统:CENTOS 6.4(64bit) 高可用软件:corosync+pacemaker host:ftp1 192.168.1.190 ftp2  192.168.1.191 stonith(ipmi):ftp1 192.168.1.180

全世界最详细的图形化VMware中linux环境下oracle安装(一)【weber出品必属精品】

安装流程:前期准备工作--->安装ORACLE软件--->安装升级补丁--->安装odbc创建数据库--->安装监听器--->安装EM <前期准备工作> 安装配置系统环境安装linux ,所有服务都不选择,只是选择安装开发工具,不要安装防火墙(当然也可以在后面关闭) 打开终端,执行如下命令,检查安装包,没有的都要安装 make, glibc, libaio compat-libstdc++, compat-gcc-34, compat-gcc-34-c++, gc

Windows 2008下 rman backup scirpts(备份脚本)--已经在生产环境下通过验证

一.任务计划 windows -控制面板-管理工具-计划任务程序,右击"任务计划程序库","创建任务" 二:相关脚本中的内容: 2.1  back_rman.bat中的内容: set ORACLE_SID=FS F:\oracle\product\10.2.0\db_1\BIN\rman target / cmdfile=H:\worksql\windows_backupscript\backup.rcv log=H:\worksql\windows_backups

生产环境下的iptables

生产环境下的iptables设置,这是我自己的一点总结,浅显之处望大家指出批评,共同学习. 我的局域网为192.168.1.0/24. 1.先清空所有规则 iptables -F iptables -X iptables -Z iptables -t nat -F iptables -t nat -X iptables -t nat -Z 设置默认规则前开发ssh(6123)端口 iptables -A INPUT -i eth0 -s 192.168.1.0/24 -p tcp --dport

读生产环境下go语言最佳实践有感

最近看了一篇关于go产品开发最佳实践的文章,go-in-procution.作者总结了他们在用go开发过程中的很多实际经验,我们很多其实也用到了,鉴于此,这里就简单的写写读后感,后续我也争取能将这篇文章翻译出来.后面我用soundcloud来指代原作者. 开发环境 在soundcloud,每个人使用一个独立的GOPATH,并且在GOPATH直接按照go规定的代码路径方式clone代码. $ mkdir -p $GOPATH/src/github.com/soundcloud $ cd $GOPA

全世界最详细的图形化VMware中linux环境下oracle安装(二)【weber出品必属精品】

<ORACLE 10.2.05版本的升级补丁安装> 首先我们解压 $ unzip p8202632_10205_LINUX.zip 解压后我们会发现多出了个文件夹,他是:Disk1,进入Disk1.然后执行安装: $ ./runInstaller 执行脚本 # /u01/app/oracle/10.2.0/db_1/root.sh Running Oracle 10g root.sh script... The following environment variables are set a