Dear All:
Hi. 当前环境:Window XP + Oracle Database 10g Enterprise Edition Release 10.1.0.2.0
最近遇到一个需求如下:
Schema的表的DML操作记录到日志表。(例如:update t set col1 = col1+5 )。
记录到日志的信息包括: 当前用户名:schema name,DML操作类型:update,DML操作的具体列名:col1 等等。因为DML操作的列是动态的,所以考虑使用stream的capture来捕获DML的信息。1、已经配置stream的帐号 strmadmin
2、strmadmin 已正确授权
3、需捕获DML的schema为scott一、登入strmadmin
1、建立队列
begin
dbms_streams_adm.set_up_queue(
queue_table => 'prod_queue_table',
queue_name => 'prod_queue',
queue_user => 'strmadmin');
end;2、创建capture进程
begin
dbms_streams_adm.add_schema_rules(
schema_name => 'scott',
streams_type => 'capture',
streams_name => 'capture_prod',
queue_name => 'strmadmin.prod_queue',
include_dml => true,
include_ddl => true,
include_tagged_lcr => false,
source_database => null,
inclusion_rule => true);
end;3、创建apply进程
begin
dbms_streams_adm.add_schema_rules(
schema_name => 'scott',
streams_type => 'apply',
streams_name => 'apply_prod',
queue_name => 'strmadmin.prod_queue',
include_dml => true,
include_ddl => true,
include_tagged_lcr => false,
source_database => null,
inclusion_rule => true);
end;4、启动capture进程
begin
dbms_capture_adm.start_capture(capture_name => 'capture_prod');
end;5、启动apply进程
begin
dbms_apply_adm.start_apply(apply_name => 'apply_prod');
end;6、设置DML操作的Handler
begin
dbms_apply_adm.set_dml_handler(
object_name => 'scott.dept',
object_type => 'TABLE',
operation_name => 'UPDATE',
error_handler => false,
user_procedure => 'strmadmin.dml_handler',
apply_database_link => null);
end; 问题1:
在步骤6中的 “user_procedure => 'strmadmin.dml_handler' ”。
我已经在strmadmin中建立了一个存储过程dml_handler,用来处理scott的dept的DML操作(UPDATE操作)。测试中,对scott的dept表,进行UPDATA操作后,发现dml_handler没有被调用。
在dml_handler中使用dbms_output.putline('procedure had been fired!');
发现控制台并未打印出该条信息。问题2:
在启动apply进程后,查看状态。
SELECT apply_name, apply_captured, status FROM dba_apply;
发现该进程状态为aborted.
请教大家:上面设置capture和apply的过程,是否正确。不甚感激。
Hi. 当前环境:Window XP + Oracle Database 10g Enterprise Edition Release 10.1.0.2.0
最近遇到一个需求如下:
Schema的表的DML操作记录到日志表。(例如:update t set col1 = col1+5 )。
记录到日志的信息包括: 当前用户名:schema name,DML操作类型:update,DML操作的具体列名:col1 等等。因为DML操作的列是动态的,所以考虑使用stream的capture来捕获DML的信息。1、已经配置stream的帐号 strmadmin
2、strmadmin 已正确授权
3、需捕获DML的schema为scott一、登入strmadmin
1、建立队列
begin
dbms_streams_adm.set_up_queue(
queue_table => 'prod_queue_table',
queue_name => 'prod_queue',
queue_user => 'strmadmin');
end;2、创建capture进程
begin
dbms_streams_adm.add_schema_rules(
schema_name => 'scott',
streams_type => 'capture',
streams_name => 'capture_prod',
queue_name => 'strmadmin.prod_queue',
include_dml => true,
include_ddl => true,
include_tagged_lcr => false,
source_database => null,
inclusion_rule => true);
end;3、创建apply进程
begin
dbms_streams_adm.add_schema_rules(
schema_name => 'scott',
streams_type => 'apply',
streams_name => 'apply_prod',
queue_name => 'strmadmin.prod_queue',
include_dml => true,
include_ddl => true,
include_tagged_lcr => false,
source_database => null,
inclusion_rule => true);
end;4、启动capture进程
begin
dbms_capture_adm.start_capture(capture_name => 'capture_prod');
end;5、启动apply进程
begin
dbms_apply_adm.start_apply(apply_name => 'apply_prod');
end;6、设置DML操作的Handler
begin
dbms_apply_adm.set_dml_handler(
object_name => 'scott.dept',
object_type => 'TABLE',
operation_name => 'UPDATE',
error_handler => false,
user_procedure => 'strmadmin.dml_handler',
apply_database_link => null);
end; 问题1:
在步骤6中的 “user_procedure => 'strmadmin.dml_handler' ”。
我已经在strmadmin中建立了一个存储过程dml_handler,用来处理scott的dept的DML操作(UPDATE操作)。测试中,对scott的dept表,进行UPDATA操作后,发现dml_handler没有被调用。
在dml_handler中使用dbms_output.putline('procedure had been fired!');
发现控制台并未打印出该条信息。问题2:
在启动apply进程后,查看状态。
SELECT apply_name, apply_captured, status FROM dba_apply;
发现该进程状态为aborted.
请教大家:上面设置capture和apply的过程,是否正确。不甚感激。
解决方案 »
- 新手,转成Oracle代码
- 求助,关于搜索结果分类排列~~
- 执行SQL报ORA-03113: end-of-file on communication channel错误,各位大侠,请帮忙看看!
- 4G内存,linux环境init文件如何配?
- 请教关于RTRIM和LTRIM的小问题
- 帮忙解决这个问题
- 简单问题,SQL脚本改写Oracle脚本,请liuyi8903、enhydraboy、black_snail各位大虾解答,在线等待,解决马上结帖!
- 首选证明问题
- 如何更改表名?
- 怎样在proc c/c++ 中调用oracle存储过程?
- 急救!操作失误,如何进行恢复,在线等--
- datastage下怎么用表中生日字段来计算年龄?
今天按楼上兄弟的方法去看一下。
我感觉是APPLY进程没有成功运行。
查看dba_apply_error,得到error_message如下:
ORA-26687: no instantiation SCN provided for "SCOTT"."DEPT" in source database "请教原帖中的配置capture和apply(第一步到第六步)的步骤是否正确呢?
公司最后决定不用STREAM来做同步了,原因是比较麻烦。
另外,似乎10G R2之后才能使用STREAM来做同步,R1不可以使用该功能。