如何从Oracle 迁移到 Mongo DB
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了如何从Oracle 迁移到 Mongo DB相关的知识,希望对你有一定的参考价值。
可以考虑将Oracle导出为平文件再导入到MongoDB。Oracle是结构化的数据库,而mongodb 是非结构化数据库无法直接导入。
具体的操作步骤=大致如下:
导出数据:
sqluldr2 USER=hh/hh@orderInfo QUERY="select *from hh.ent_person" table=test head=yes FILE=test.csv
导入数据:
mongoimport -h 10.0.0.20 -d testdb -c orderInfo --type csv --file test.csv --headerline --upsert 参考技术A 工作空间管理器(工作空间管理窗口)中,选中数据源图标,单击鼠标右键,从弹出的快捷菜单中选择“新建数据源…”。
SuperMap支持以下几种数据库:
SDB(文件型数据库,类似Access)
Oracle
MS SQL Server
Sybase ASE
DB2
DM
Kingbase ES
不用感谢我也是复制别人的!本回答被提问者和网友采纳 参考技术B 数据迁移的话可以用代码来做,先从oracle读取数据,然后在插入到oracle中
多租户:在Oracle12.2中 从Non-CDB迁移到PDB,从PDB迁移另一个CDB中
1、从PDB或者Non-CDB迁移到另一个CDB的PDB准备从PDB或者Non-CDB迁移到CDB容器数据库中PDB,由于PDB和Non-CDB迁移到CDB的步骤几乎相同,PDB和Non-CDB迁移非常相似,共同进行处理。
准备:
CDB1:目标pdb数据库的容器数据库
db12c: 需要迁移的Non-CDB
CDB3: 需要迁移pbd的容器数据库
2、在Oracle DB12C克隆远程PDB或者Non-CDB
--注:local代表目的或者目标CDB端,remote代表PBD或者Non-CDB 的源端。
**--2.1克隆的步骤**
/*
1、在目标端跟容器中,必须拥有CREATE PLUGGABLE DATABASE的权限。
2、源端数据库 (PDB or non-CDB)必须开启read-only模式。
3、目标端数据库须有一个database link链接源端数据库,如果是PBD,database link使用普通用户指向源端CDB或者PDB用目标端或普通用户
4、源数据库的database link用户必须拥有CREATE PLUGGABLE DATABASE权限。
5、目标数据库和源数据库必须拥有相同的安装选项和字符集;
6、克隆前必须配置TDE;
7、目标端CDB中必须存在源端的默认表空间。如果不存在,新的PDB只能用restricted 模式打开。
8、克隆Non-CDB时,源端和目标端的数据库必须使用12.1.0.2以上版本。
*/
2.2 克隆Remote PDB
--1.设置环境
export ORAENV_ASK=NO export ORACLE_SID=cdb3 . oraenv export ORAENV_ASK=YES sqlplus / as sysdba
--2.在remote端创建用户,用于db_link
alter session set container=pdb5; create user remote_clone_user identified by remote_clone_user; grant create session,create pluggable database to remote_clone_user;
--3.在remote端的PDB中打开read only模式
conn / as sysdba alter pluggable database pdb5 close; alter pluggable database pdb5 open read only; exit;
--4.在local端的“tnsnames.ora”中添加本地链接名称,供db_link使用
PDB5 = (DESCRIPTION = (ADDRESS_LIST = (ADDRESS = (PROTOCOL = TCP)(HOST = 192.168.2.81)(PORT = 1521)) ) (CONNECT_DATA = (SERVICE_NAME = pdb5) ) )
--5.连接local端开始克隆
export ORAENV_ASK=NO export ORACLE_SID=cdb1 . oraenv export ORAENV_ASK=YES sqlplus / as sysdba
--6.在local端创建数据库连接
drop database link clone_link; create database link clone_link connect to remote_clone_user identified by remote_clone_user using 'pdb5';
--测试连接
desc [email protected]_link;
--7.在local端数据库创建新的PDB
create pluggable database pdb5new from [email protected]_link;
--8、查看新的PDB和其状态
select name,open_mode from v$pdbS where name='PDB5NEW';
--9、以read-write模式打开PDB
alter pluggable database pdb5new open; select name,open_mode from v$pdbs where name ='PDB5NEW';
**--2.3 克隆Non-CDB**
--1.设置环境
export ORAENV_ASK=NO export ORACLE_SID=db12c . oraenv export ORAENV_ASK=YES sqlplus / as sysdba
--2.在remote端创建用户,用于db_link
create user remote_clone_user identified by remote_clone_user; grant create session,create pluggable database to remote_clone_user;
--3.在remote端的PDB中打开read only模式
shutdown immediate; startup mount; alter database read only; exit;
--4.在local端的“tnsnames.ora”中添加本地链接名称,供db_link使用
DB12C = (DESCRIPTION = (ADDRESS_LIST = (ADDRESS = (PROTOCOL = TCP)(HOST = 192.168.1.93)(PORT = 1521)) ) (CONNECT_DATA = (SERVICE_NAME = PDF) ) )
--5.连接local端开始克隆
export ORAENV_ASK=NO export ORACLE_SID=cdb1 . oraenv export ORAENV_ASK=YES sqlplus / as sysdba
--6.在local端创建数据库连接
drop database link clone_link; create database link clone_link connect to remote_clone_user identified by remote_clone_user using 'db12c';
--测试连接
desc [email protected]_link;
--7.在local端数据库创建新的PDB
create pluggable database db12cpdb from [email protected]_link;
--8.查看新的PDB和其状态
select name,open_mode from v$pdbS where name='DB12CPDB';
--9.运行以下脚本清除non-CDB到PDB信息
alter session set container=db12cpdb; @$ORACLE_HOME/rdbms/admin/noncdb_to_pdb.sql
--10.以read-write模式打开PDB
ALTER PLUGGABLE DATABASE db12cpdb OPEN; select name,open_mode from v$pdbs where name ='DB12CPDB';
**--2.4 将non-cdb数据库迁移到位PDB**
--1.关闭non-cdb并以read-only模式打开
export ORACLE_SID=db12c sqlplus / as sysdba shutdown immediate; startup open read only;
--2.使用dbms_pbd.describe过程创建xml文件
begin dbms_pdb.describe( pdb_descr_file =>'/tmp/db12c.xml'); end;
--3.关闭non-cdb数据库
exprot ORACLE_SID=db12c sqlplus / as sysdba
shutdown immediate;
--4.使用non-cdb的描述文件在CDB中创建PDB
export ORACLE_SID=cdb1 sqlplus / as sysdba
craete pluggable database pdb6 using '/tmp/db12c.xml' copy file_name_convert =('/u01/app/oracle/oradata/db12c/', '/u01/app/oracle/oradata/cdb1/pdb6/');
--5.切换到pdb6,运行如下脚本
alter session set container = pdb6; @$ORACLE_HOME/rdbms/admin/noncdb_to_pdb.sql
--6.启动PDB,检查open_mode
alter session set container =pdb6; alter pluggable database open ;
select name,open_mode from v$pdbs;
**--2.5 数据迁移**
--方案一:使用 data dump (expdp/impdp)
--使用 data dump (expdp/impdp)从non-cdb迁移到新创建的PDB数据库中。如果non-cdb是11.2.0.3以上的版本以下的版本,expdp使用"FULL=Y TRANSPORTABLE=ALWAYS VERSION=12"参数。如果在不同的平台进行转换需要使用RMAN的convert命令,或者DBMS_FILE_TRANSFER包。
--方案二:使用Goldengate
--使用Goldengate的replicate将数据从non-cdb传输到pdb上。
**--2.6 补丁考虑**
--如果源端和目标端的补丁基本不一样,需要从PDB的PDB_PLUG_IN_VIOLATIONS试图中查看,并且使用datapatch工具在目标端进行扫描,并实施相关补丁。
以上是关于如何从Oracle 迁移到 Mongo DB的主要内容,如果未能解决你的问题,请参考以下文章