2012-02-13 95 views
0

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

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

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

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

回答

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并使用完全限定的表名。