在Sql server 2005中验证数据迁移

时间:2012-02-13 22:48:52

标签: tsql

我正在将数据从非unicode数据库表迁移到unicode数据库表。 我们有大约40个表,至少需要对迁移的数据进行行计数验证。

重复编写相同的代码以验证所有表格似乎是错误的方法。

那么验证数据迁移的正确方法是什么。

我正在使用T-SQL并寻找一些代码样本来进行行计数检查。

1 个答案:

答案 0 :(得分:0)

此查询将比较两个数据库中的表,并返回其中一个数据库中行数不同或表缺失的表。将AAABBB替换为系统中的数据库名称。

SELECT 
    DbB.Name DbBName, DbA.Rows DbARows, DbB.Rows DbBRows
FROM
    (
    SELECT DISTINCT p.rows Rows, tbl.name Name
    FROM  AAA.sys.tables AS tbl INNER JOIN AAA.sys.partitions AS p ON p.object_id = tbl.object_id
    ) DbA
    FULL OUTER JOIN 
    (
    SELECT DISTINCT p.rows Rows, tbl.name Name
    FROM  BBB.sys.tables AS tbl INNER JOIN BBB.sys.partitions AS p ON p.object_id = tbl.object_id
    ) DbB ON DbA.Name = DbB.Name
WHERE
    DbA.Rows <> DbB.Rows OR DbA.Rows IS NULL OR DbB.Rows IS NULL

如果数据库位于不同的服务器上,请创建Linked Server并使用完全限定的表名。