标签云
asm恢复 bbed bootstrap$ dul In Memory kcbzib_kcrsds_1 kccpb_sanity_check_2 MySQL恢复 ORA-00312 ORA-00607 ORA-00704 ORA-00742 ORA-01110 ORA-01555 ORA-01578 ORA-01595 ORA-08103 ORA-600 2131 ORA-600 2662 ORA-600 3020 ORA-600 4000 ORA-600 4137 ORA-600 4193 ORA-600 4194 ORA-600 16703 ORA-600 kcbzib_kcrsds_1 ORA-600 KCLCHKBLK_4 ORA-15042 ORA-15196 ORACLE 12C oracle dul ORACLE PATCH Oracle Recovery Tools oracle加密恢复 oracle勒索 oracle勒索恢复 oracle异常恢复 Oracle 恢复 ORACLE恢复 ORACLE数据库恢复 oracle 比特币 OSD-04016 YOUR FILES ARE ENCRYPTED 勒索恢复 比特币加密文章分类
- Others (2)
- 中间件 (2)
- WebLogic (2)
- 操作系统 (103)
- 数据库 (1,769)
- DB2 (22)
- MySQL (77)
- Oracle (1,610)
- Data Guard (52)
- EXADATA (8)
- GoldenGate (24)
- ORA-xxxxx (166)
- ORACLE 12C (72)
- ORACLE 18C (6)
- ORACLE 19C (15)
- ORACLE 21C (3)
- Oracle 23ai (8)
- Oracle ASM (69)
- Oracle Bug (8)
- Oracle RAC (54)
- Oracle 安全 (6)
- Oracle 开发 (28)
- Oracle 监听 (29)
- Oracle备份恢复 (592)
- Oracle安装升级 (97)
- Oracle性能优化 (62)
- 专题索引 (5)
- 勒索恢复 (86)
- PostgreSQL (30)
- pdu工具 (6)
- PostgreSQL恢复 (9)
- SQL Server (32)
- SQL Server恢复 (13)
- TimesTen (7)
- 达梦数据库 (3)
- 达梦恢复 (1)
- 生活娱乐 (2)
- 至理名言 (11)
- 虚拟化 (2)
- VMware (2)
- 软件开发 (39)
- Asp.Net (9)
- JavaScript (12)
- PHP (2)
- 小工具 (22)
-
最近发表
- 2025年的Oracle 8.0.5数据库恢复
- ORA-600 kokiasg1故障分析(obj$中核心字典序列全部被恶意删除)
- ORA-00756 ORA-10567故障数据0丢失恢复
- 数据库文件变成32k故障恢复
- tcp连接过多导致监听TNS-12532 TNS-12560 TNS-00502错误
- 文件系统格式化MySQL数据库恢复
- .sstop勒索加密数据库恢复
- 解决一次硬件恢复之后数据文件0kb的故障恢复case
- Error in invoking target ‘libasmclntsh19.ohso libasmperl19.ohso client_sharedlib’问题处理
- ORA-01171: datafile N going offline due to error advancing checkpoint
- linux环境oracle数据库被文件系统勒索加密为.babyk扩展名溯源
- ORA-600 ksvworkmsgalloc: bad reaper
- ORA-600 krccfl_chunk故障处理
- Oracle Recovery Tools恢复案例总结—202505
- ORA-600 kddummy_blkchk 数据库循环重启
- 记录一次asm disk加入到vg通过恢复直接open库的案例
- CHECKDB 发现了 N 个分配错误和 M 个一致性错误
- 达梦数据库dm.ctl文件异常恢复
- Oracle Recovery Tools修复ORA-00742、ORA-600 ktbair2: illegal inheritance故障
- 可能是 tempdb 空间用尽或某个系统表不一致故障处理
月归档:二月 2011
goldengate同步sql server to oracle
准备工作,在sql server机器上建立odbc连接
一、初始化加载数据
1、source端
1)添加extract进程
ADD EXTRACT einito, SOURCEISTABLE edit param einito --以下添加到einito.prm文件中 EXTRACT einito SOURCEDB mssql_test RMTHOST 127.0.0.1, MGRPORT 7815 RMTTASK REPLICAT, GROUP rinitm TABLE dbo.t1;
2)生成defgen文件
edit params defgen ---以下为defgen.prm中内容 defsfile F:\ogg\mssql\dirdef\t1.def sourcedb mssql_test table dbo.t1; --退出ggsci(ogg安装目录dos下) exit defgen paramfile F:\ogg\mssql\dirprm\defgen.prm
2、target端
1)replicat 进程
ADD REPLICAT rinitm, SPECIALRUN edit params rinitm --以下内容在rinitm.prm文件中 replicat rinitm sourcedefs F:\ogg\oracle\dirdef\t1.def SETENV (NLS_LANG =AMERICAN_AMERICA.ZHS16GBK) USERID chf, PASSWORD xifenfei DISCARDFILE F:\ogg\oracle\dirrpt\RINItm.dsc, append MAP "dbo.t1", TARGET CHF.T1_1;
二、数据同步
1、source端
1)添加附件日志
dblogin sourcedb mssql_test add trandata dbo.t1
2)摄取进程(extract)
add extract extm,tranlog,begin now ADD EXTTRAIL F:\ogg\mssql\dirdat\ms, EXTRACT EXTM edit param extm --以下为extm.prm内容 extract extm SOURCEDB mssql_test exttrail F:\ogg\mssql\dirdat\ms dynamicresolution gettruncates tranlogoptions managesecondarytruncationpoint TABLE dbo.t1;
3)传递进程(data pump extract )
ADD EXTRACT pump1, EXTTRAILSOURCE F:\ogg\mssql\dirdat\ms, BEGIN now add rmttrail F:\ogg\oracle\dirdat\or extract pump1 edit params pump1 --以下为pump1.prm内容 extract pump1 SOURCEDB mssql_test --需要,不然不能获得数据 rmthost 127.0.0.1, mgrport 7815 rmttrail F:\ogg\oracle\dirdat\or PASSTHRU gettruncates TABLE dbo.t1;
2、target端
1)设置检查点表
edit params ./GLOBALS --下面一句为GLOBALS文件中内容 CHECKPOINTTABLE ogg.chkpoint dblogin userid ogg,password xifenfei ADD CHECKPOINTTABLE ogg.chkpoint
2)replicat进程
add replicat repl exttrail F:\ogg\oracle\dirdat\or,begin now,checkpointtable ogg.chkpoint edit params repl --以下为repl.prm中内容 replicat repl SETENV (NLS_LANG =AMERICAN_AMERICA.ZHS16GBK) userid ogg,password xifenfei sourcedefs F:\ogg\oracle\dirdef\t1.def reperror default,discard discardfile F:\ogg\oracle\dirtmp\repsz.dsc,append,megabytes 100 gettruncates MAP "dbo.t1", TARGET CHF.T1_1;
note:
因为defgen中的表名为小写,所以在replicat相关进程中,map表需要使用双引号小写
发表在 GoldenGate
评论关闭
oracle修改表增加列删除列修改列
1.增加列
ALTER TABLE table_name ADD( column datatype [DEFAULT EXPR][,column datatype...]);
例如:
SQL>ALTER TABLE emp01 ADD eno NUMBER(4);
2.修改列定义
例如:
SQL>ALTER TABLE emp01 MODIFY job VARCHAR2(15)
2 DEFAULT ‘CLERK’
3.删除列
例如:
SQL> ALTER TABLE emp01 DROP COLUMN dno;
4.修改列名
例如:
SQL>ALTER TABLE emp01 RENAME COLUMN eno TO empno;
5.修改表名
例如:
SQL>RENAME emp01 TO employee;
6.增加注释
例如:
SQL>COMMENT ON TABLE employee IS ‘存放雇员信息’;
发表在 Oracle
评论关闭
goldengate 异常处理
异常处理一(异常表通用型)
新建异常处理表
create table ogg.exception_log ( replicat_name varchar2(10), table_name varchar2(100), errno number, dberrmsg varchar2(4000), optype varchar2(20), errtype varchar2(20), logrba number, logposition number, committimestamp timestamp, primary key(logrba,logposition,committimestamp) );
REPLICAT添加异常处理
REPERROR (DEFAULT, EXCEPTION) REPERROR (DEFAULT2,discard)---abend根据需求 map chf.a_t_1, target chf.a_t_1; map chf.a_t_1, target ogg.exception_log, EXCEPTIONSONLY, INSERTALLRECORDS, COLMAP ( replicat_name = "repl" , table_name = @GETENV ("GGHEADER", "TABLENAME") , errno = @GETENV ("LASTERR", "DBERRNUM") , dberrmsg = @GETENV ("LASTERR", "DBERRMSG") , optype = @GETENV ("LASTERR", "OPTYPE") , errtype = @GETENV ("LASTERR", "ERRTYPE") , logrba = @GETENV ("GGHEADER", "LOGRBA") , logposition = @GETENV ("GGHEADER", "LOGPOSITION") , committimestamp = @GETENV ("GGHEADER", "COMMITTIMESTAMP")); --实例中只处理chf.a_t_1表
异常处理二(异常表需要定制)
新建表(正常表和异常表)
--正常表 create table fei_1_1(id number , name varchar2(1000)); --异常表 create table ogg.exception_fei_1 ( id number, name varchar2(1000), table_name varchar2(100), errno number, dberrmsg varchar2(4000), optype varchar2(20), errtype varchar2(20), logrba number, logposition number, committimestamp timestamp, primary key(logrba,logposition,committimestamp) );
异常处理程序
map chf.fei_1, target chf.fei_1_1; map chf.fei_1, target ogg.exception_fei_1, EXCEPTIONSONLY, INSERTALLRECORDS, COLMAP ( USEDEFAULTS , table_name = @GETENV ("GGHEADER", "TABLENAME") , errno = @GETENV ("LASTERR", "DBERRNUM") , dberrmsg = @GETENV ("LASTERR", "DBERRMSG") , optype = @GETENV ("LASTERR", "OPTYPE") , errtype = @GETENV ("LASTERR", "ERRTYPE") , logrba = @GETENV ("GGHEADER", "LOGRBA") , logposition = @GETENV ("GGHEADER", "LOGPOSITION") , committimestamp = @GETENV ("GGHEADER", "COMMITTIMESTAMP"));
异常处理三(通配符MAPEXCEPTION)
新建异常表
create table ogg.exception_fei_all ( replicat_name varchar2(10), table_name varchar2(100), errno number, dberrmsg varchar2(4000), optype varchar2(20), errtype varchar2(20), logrba number, logposition number, committimestamp timestamp, primary key(logrba,logposition,committimestamp) );
异常处理程序
MAP chf.fei_*, TARGET chf.*, MAPEXCEPTION (TARGET ogg.exception_fei_all, COLMAP ( replicat_name = "repl" , table_name = @GETENV ("GGHEADER", "TABLENAME") , errno = @GETENV ("LASTERR", "DBERRNUM") , dberrmsg = @GETENV ("LASTERR", "DBERRMSG") , optype = @GETENV ("LASTERR", "OPTYPE") , errtype = @GETENV ("LASTERR", "ERRTYPE") , logrba = @GETENV ("GGHEADER", "LOGRBA") , logposition = @GETENV ("GGHEADER", "LOGPOSITION") , committimestamp = @GETENV ("GGHEADER", "COMMITTIMESTAMP")));
处理说明:
REPERROR参数用以控制Replicat进程如何响应映射过程中发生的错误
DEFAULT参数代表一种全局错误类型,即除去所有已明确指定的错误外的一切错误
DEFAULT2参数代表当DEFAULT错误以Exception方式响应时,所有MAP映射中未定义Exception部分出现的所有错误
EXCEPTIONSONLY只能用于确定表的异常处理
MAPEXCEPTION可以用于通配符的表异常处理
发表在 GoldenGate
2 条评论