使用物化视图解决GoldenGate不能使用中文表名问题
源端:
conn sh/sh
create table "学生" ("学号" number primary key,"姓名" varchar2(30))
*
ORA-00957: duplicate column name 重复列名
create table "学生" ("学号" number primary key, " 姓名" varchar2(30));
create materialized view log on "学生" with primary key;
create materialized view mv_student
refresh fast on commit
as
select "学生"."学号" as id, "学生"." 姓名" as name from "学生";
添加这个物化视图的附加日志
GGSCI (linux5.5) 1> dblogin userid goldengate, password goldengate
info trandata sh.mv_student
add trandata sh.mv_student
SQL> select * from tab;
TNAME TABTYPE CLUSTERID
------------------------------ ------- ----------
TEST TABLE
TEST1 TABLE
TEST4 TABLE
???? TABLE
MLOG$_???? TABLE
RUPD$_???? TABLE
MV_STUDENT TABLE
一个一个指定,不能用模糊匹配,否则物化视图的日志、中文表,物化视图也会复制过去
GGSCI (linux5.5) 3> edit params ext_sh
TABLE SH.test1;
TABLE SH.test4;
TABLE SH.mv_student;
GGSCI (linux5.5) 5> stop ext_sh
GGSCI (linux5.5) 7> start ext_sh
SQL> desc sh."学生"
Name Null? Type
----------------------------------------- -------- ----------------------------
???? NOT NULL NUMBER
???? VARCHAR2(30)
如果用模糊匹配:
SQL> select * from tab;
TNAME TABTYPE CLUSTERID
------------------------------ ------- ----------
TEST1 TABLE
TEST4 TABLE
???? TABLE
BIN$6TRNVHJWkIHgQKjAqQoNFg==$0 TABLE
MLOG$_???? TABLE
RUPD$_???? TABLE
SQL> desc sh."学生"
ORA-00942: table or view does not exist
目标端
dblogin userid goldengate, password goldengate
add checkpointtable goldengate.rep_mv_ckpt
add replicat rep_mv,exttrail ./dirdat/d2,checkpointtable rep_mv_ckpt
GGSCI (linux5.5) 5> edit params rep_sh
mapexclude sh.mv_student
GGSCI (linux5.5) 7> stop rep_sh
GGSCI (linux5.5) 9> start rep_sh
GGSCI (linux5.5) 10> info all
Program Status Group Lag at Chkpt Time Since Chkpt
MANAGER RUNNING
REPLICAT STOPPED REP_MV 00:00:00 00:04:37
REPLICAT RUNNING REP_OE 00:00:00 00:00:03
REPLICAT RUNNING REP_SH 00:09:26 00:00:03
REPLICAT RUNNING REP_T1 00:00:00 00:00:01
REPLICAT RUNNING REP_T401 00:00:00 00:00:01
REPLICAT RUNNING REP_T402 00:00:00 00:00:01
REPLICAT RUNNING REP_T403 00:00:00 00:00:01
GGSCI (linux5.5) 7> edit params rep_mv
REPLICAT rep_mv
SETENV (NLS_LANG="American_America.ZHS16GBK")
SETENV (ORACLE_SID=test)
USERID goldengate,PASSWORD goldengate
REPORTCOUNT EVERY 30 MINUTES, RATE
REPERROR DEFAULT, ABEND
numfiles 5000
--HANDLECOLLISIONS
assumetargetdefs
DISCARDFILE ./dirrpt/rep_mv.dsc, APPEND, MEGABYTES 1000
ALLOWNOOPUPDATES
DDL INCLUDE MAPPED
DDLOPTIONS REPORT
map sh.mv_student, target sh.mv_student;
GGSCI (linux5.5) 9> start rep_mv
初始化:
conn sh/sh
create table "学生" ("学号" number primary key, " 姓名" varchar2(30));
create or replace view mv_student
as
select "学生"."学号" as id, "学生"." 姓名" as name from "学生";
GGSCI (linux5.5) 10> alter replicat rep_mv, begin now 把以前没有执行的事务直接抛弃掉
源端:
conn sh/sh
insert into "学生" values (4,'张三4');
commit;
目标端
select * from "学生";
使用物化视图解决GoldenGate不能使用中文表名问题的更多相关文章
- 解决mysql shell执行中文表名报command not found错误
mysql -h 192.168.22.201 -uusername -ppassword --default-character-set=utf8 rom3 -e "DELETE FROM ...
- Oracle 查询库中所有表名、字段名、字段名说明,查询表的数据条数、表名、中文表名、
查询所有表名:select t.table_name from user_tables t;查询所有字段名:select t.column_name from user_col_comments t; ...
- db2 中文表名和字段
建库语句 create db test on D: using codeset GBK territory CN 或者 territory cn codeset 和 territory 都是需要指定 ...
- Android GreenDao 中文表名,中文字段DAO生成乱码的问题
在gradle.properties 文件中加入编码类型 # Project-wide Gradle settings. # IDE (e.g. Android Studio) users: # Gr ...
- calcite物化视图详解
概述 物化视图和视图类似,反映的是某个查询的结果,但是和视图仅保存SQL定义不同,物化视图本身会存储数据,因此是物化了的视图. 当用户查询的时候,原先创建的物化视图会注册到优化器中,用户的查询命中物化 ...
- postgres中的视图和物化视图
视图和物化视图区别 postgres中的视图和mysql中的视图是一样的,在查询的时候进行扫描子表的操作,而物化视图则是实实在在地将数据存成一张表.说说版本,物化视图是在9.3 之后才有的逻辑. 比较 ...
- Oracle数据库入门——如何根据物化视图日志快速刷新物化视图
Oracle物化视图的快速刷新机制是通过物化视图日志完成的.Oracle如何通过一个物化视图日志就可以支持多个物化视图的快速刷新呢,本文简单的描述一下刷新的原理. 首先,看一下物化视图的结构:SQL& ...
- Oracle数据库入门——物化视图语法
一.Oracle物化视图语法 create materialized view [view_name]refresh [fast|complete|force][on [commit|demand] ...
- Oracle 物化视图 说明
一. 物化视图概述 Oracle的物化视图是包括一个查询结果的数据库对像,它是远程数据的的本地副本,或者用来生成基于数据表求和的汇总表.物化视图存储基于远程表的数据,也可以称为快照. 物化视图可 ...
随机推荐
- DB-MySQL:目录
ylbtech-DB-MySQL:目录 1.返回顶部 2.返回顶部 3.返回顶部 4.返回顶部 5.返回顶部 6.返回顶部 作者:ylbtech出处:http://ylbt ...
- POJ 3693 后缀数组+RMQ
思路: 论文题 后缀数组&RMQ 有一些题解写得很繁 //By SiriusRen #include <cmath> #include <cstdio> #includ ...
- asp.net 连接字符串的多种写法
一.使用OleDbConnection对象连接OLE DB数据源 1.连接Access 数据库 Access 2000: “provider=Microsoft.Jet.Oledb.3.5;Data ...
- python内置的一些模块
logging模块: 默认情况下,logging将日志打印到屏幕,日志级别为WARNING:日志级别大小关系为:CRITICAL > ERROR > WARNING > INFO & ...
- SpringCloud学习笔记(17)----Spring Cloud Netflix之服务网关Zuul的使用
1. 什么时候Zuul? Zuul是一个基于jvm路由和服务端的负载均衡器,在云平台上提供动态路由,监控,弹性,安全等边缘服务的框架. 路由功能:相当于nginx的反向代理 比如: / 可能需要映射到 ...
- VB学习笔记(一)VB操作字符串
在vb中 dim a# 定义a变量为双精度型变量~ #是类型符 % 整型 & 长整型 !单精度 $ 字符型 VB中strconv 的作用 StrConv("要转换的字符串" ...
- redis搭建与安装2
第一步redis安装:1.首先确认下载包为64位的还是32位的2.下载http://code.google.com/p/servicestack/downloads3.解压下载包得到以下文件:cygw ...
- yum-config-manager --add-repo=
[root@server0 yum.repos.d]# yum-config-manager --add-repo=ftp://192.168.31.121/centos7u4Loaded plugi ...
- 教你用webpack搭一个vue脚手架[超详细讲解和注释!]
1.适用人群 1.对webpack知识有一定了解但不熟悉的同学. 2.女同学!!!(233333....) 2.目的 在自己对webpack有进一步了解的同时,也希望能帮到一些刚接触webpack的同 ...
- 集合框架(List和Set)
一.概述 集合是一种可变数据项的容器,具有统一的父类接口Collection<E>(Map并没有继承之),与其子集合的关系例如以下 图.集合的特点是长度可变,能够存储多种类型的对象(不加泛 ...