在Sql server 2005验证数据迁移
问题描述:
我正在将数据从非unicode数据库表迁移到unicode数据库表。 我们有大约40个表格,需要对迁移的数据至少进行行计数验证。在Sql server 2005验证数据迁移
重复编写相同的代码来验证所有表格似乎是错误的方法。
那么,验证数据迁移的正确方法是什么。
我正在使用T-SQL并寻找一些代码示例来进行行数检查。
答
此查询将比较两个数据库中的表,并返回其中一个数据库中行数不同或表丢失的那些表。将AAA
和BBB
替换为系统中的数据库名称。
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
并使用完全限定的表名。