由于暂时没有办法在源端做一些额外的操作,所以,使用OGG同步的数据就需要人工去进行校验。在这里分享一下我的校验方法,请大家多多指正。我会逐步完善这篇帖子。
- 行数的比对
行数的校验使用count的方式来进行对比
select count(1) from owner.table_name;
- 哈希值的比对
哈希值的校验,是通过数据库的dbms_utility.get_hash_value,来获取表的每一行的哈希值来进行对比,然后通过sum取所有行的哈希值的总数,来进行源端和目标端的比对。此方法有一个缺陷,就是表的字段总大小不能超过4000字节。
(个人想法:对于表的字段总大小超过4000字节的,可以在脚本中将表的字段进行拆分,即脚本1先查询前30个字段的哈希值,脚本2查询30-60的字段的哈希值)
可以通过下面的脚本来获取表的哈希值。
select 'select sum(dbms_utility.get_hash_value('||column_name_path||',0,power(2,30)) ) '||table_name||'
from '||owner||'.'||table_name||';' from (select owner,table_name,column_name_path,row_number()
over(partition by table_name order by table_name,curr_level desc) column_name_path_rank
from (select owner,table_name,column_name,rank,level as curr_level,
ltrim(sys