上一篇“导出记录数量对比-软件测试方法(一)”,主要介绍数据导出结果记录数量和原始正常好库的记录数量精确对比,测试软件导出少数据的相关bug。
本文测试方法旨在更精确比对表记录内部数据差异,记录数量的对比只是恢复准确率的必要条件,而记录内部的字段数据内容是否一致,才是比较的终极目标。

一、 测试目的:在很多情况下,数据导出是以记录数量来衡量是否齐全。在某些情况下,数据记录数量导出是一致的,但,记录内部数据却出现差异,比如某些数字字段,一旦出现差异,其结果将带来不准确。本测试大纲目的是比对表中记录数据是否有差异,一旦出现差异,想办法修改软件,达到更准确的恢复效果。

二、测试工具:tablediff.exe,这个工具就用于表内部数据比较,是MS SQL Server自带的一个工具。各位可以自行搜索自己机器上的这个文件所在的路径。

sql server 怎么比对两个库的表的列 sql 比对两个表数据_SQL

三、构建数据表比较SQL语句:

use UFDATA_006_2015_好酷

SELECT ‘tablediff.exe -sourceserver 127.0.0.1\SQL2008R2 -sourceuser sa -sourcepassword dst -sourcedatabase UFDATA_006_2015_好酷 -sourceschema dbo -sourcetable ‘+object_name (id)
+’ -destinationserver 127.0.0.1\SQL2008R2 -destinationuser sa -destinationpassword dst -destinationdatabase UFDATA_006_2015_好酷_out -destinationschema dbo -destinationtable ’
+object_name (id)+’ -et Difference -f c:\data’+object_name (id)+’.sql’ as SQL
from sysObjects where type =‘U’


解析:-sourceserver 127.0.0.1\SQL2008R2 原始数据库实例
sourceuser sa -sourcepassword dst -sourcedatabase UFDATA_006_2015_好酷
sa是原始数据库用户,dst是sa用户的密码,各位根据自己的设置更改,UFDATA_002_2017_原始好库是原始数据库。
-destinationserver 127.0.0.1\SQL2008R2 -destinationuser sa -destinationpassword dst -destinationdatabase UFDATA_002_2017_好库导出
127.0.0.1\SQL2008R2 是目标数据库实例,可以跨越实例比较,sa dst UFDATA_006_2015_好酷_out 都是目标数据库用户名、密码、库名称

f c:\data’+object_name (id)+’.sql’ 这个是把比较结果,写道c:\data目录下,用表的名字命名。

sql server 怎么比对两个库的表的列 sql 比对两个表数据_数据_02


四、语句执行方法:

找到tablediff.exe文件路径

sql server 怎么比对两个库的表的列 sql 比对两个表数据_MS SQL Server数据库_03


进入cmd模式下,在路径上输入cmd,回车

sql server 怎么比对两个库的表的列 sql 比对两个表数据_数据_04


sql server 怎么比对两个库的表的列 sql 比对两个表数据_SQL_05


把得到的SQL语句复制,贴到cmd窗口上。

sql server 怎么比对两个库的表的列 sql 比对两个表数据_MS SQL Server数据库_06


建好c:\data 目录,修改好权限

sql server 怎么比对两个库的表的列 sql 比对两个表数据_数据_07

设置sa登录,及密码

sql server 怎么比对两个库的表的列 sql 比对两个表数据_数据_08

sql server 怎么比对两个库的表的列 sql 比对两个表数据_数据库表的比较_09

把得到的SQL语句复制,贴到cmd窗口上:

sql server 怎么比对两个库的表的列 sql 比对两个表数据_数据库修复_10

自动运行:

sql server 怎么比对两个库的表的列 sql 比对两个表数据_SQL_11

五、等待运行结果

sql server 怎么比对两个库的表的列 sql 比对两个表数据_数据库修复_12

总结查看不同的结果,把结果做成汇总,如若发现大的出入,有可能的话可提供数据库给我。