比较两个表数据完全一致的sql
现在需要完成一个sql,比较两个表数据完全一致(两个表结构肯定是一致的).
我现在是通过minus功能来完成
如果 两个表 minus的结果等于0,那么证明这两个表完全一致
当然之前肯定还做一个两个表行数的比较,首先要保证两个表行数一致的,
感觉这样写出来的东东代码是比较少,但是不知效率如何 ,请大虾指点一下才好啊
下面是整个存储过程,已经调试通过了,大虾看看如何啊
create or replace procedure compareTableData(srcTable in
varchar2 , destTable in varchar2 , oi_return out int)
is
--源表格
src_table varchar2(32);
--目标表格
dest_Table varchar2(32);
--源表格行数
src_table_count int;
--目标表格函数
dest_table_count int;
--两个表格数据(即结果集)之间的差集的个数
minus_count int;
selectSrcSql varchar2(100);
selectDestSql varchar2(100);
selectMinusSql varchar2(200);
--错误描述
v_err_desc varchar2(100);
begin
oi_return :=0;
dbms_output.put_line(oi_return);
src_table := srcTable;
dest_Table := destTable;
--构建查询源表行数的动态sql
selectSrcSql:=' select count(*) from '||src_table;
DBMS_OUTPUT.PUT_LINE(selectSrcSql);
--执行查询源表行数的动态sql
execute immediate selectSrcSql Into src_table_count;
--构建查询源目标行数的动态sql
selectDestSql:=' select count(*) from ' ||dest_Table;
DBMS_OUTPUT.PUT_LINE(selectDestSql);
--执行查询源目标行数的动态sql
execute immediate selectDestSql Into dest_table_count;
--构建查询两个表差集行数的动态sql
selectMinusSql:='select count(*) from (
select * from ' ||src_table||
' minus
select * from ' ||dest_table|| ')';
DBMS_OUTPUT.PUT_LINE(selectMinusSql);
--如果表格行数不一致,那么证明两个表结果集肯定不一致
if(src_table_count!=dest_table_count)
then
oi_return:= src_table_count-dest_table_count;
else
--执行查询两个表差集行数的动态sql
execute immediate selectMinusSql into minus_count;
--返回差集个数,如果是0,那么证明两个表结果集肯定一致 ,反之不一致
oi_return := minus_count;
end if;
EXCEPTION
WHEN OTHERS THEN
v_err_desc := 'Error' || TO_CHAR(SQLCODE) || ':' || SQLERRM;
oi_return:= SQLCODE;
DBMS_OUTPUT.PUT_LINE(v_err_desc);
end compareTableData;