我正在尝试计算 SQL Server 2008 中整个表的校验和或哈希。我遇到的问题是该表包含 XML 列数据类型,校验和无法使用该数据类型,必须将其转换为 nvarchar第一的。所以我需要将其分解为两个问题:
- 计算一行的校验和,模式在运行前是未知的。
- 计算所有行的校验和以获得全表校验和。
您可以使用校验和_AGG http://msdn.microsoft.com/en-us/library/ms188920.aspx。它只需要一个参数,所以你可以这样做CHECKSUM_AGG(CHECKSUM(*))
- 但这不适用于您的 XML 数据类型,因此您必须求助于动态 SQL。
您可以动态生成列列表INFORMATION_SCHEMA.COLUMNS
然后将 int 插入到模板中:
DECLARE @schema_name NVARCHAR(MAX) = 'mySchemaName';
DECLARE @table_name NVARCHAR(MAX) = 'myTableName';
DECLARE @column_list NVARCHAR(MAX);
SELECT @column_list = COALESCE(@column_list + ', ', '')
+ /* Put your casting here from XML, text, etc columns */ QUOTENAME(COLUMN_NAME)
FROM INFORMATION_SCHEMA.COLUMNS
WHERE TABLE_NAME = @table_name
AND TABLE_SCHEMA = @schema_name
DECLARE @template AS varchar(MAX)
SET @template = 'SELECT CHECKSUM_AGG(CHECKSUM({@column_list})) FROM {@schema_name}.{@table_name}'
DECLARE @sql AS varchar(MAX)
SET @sql = REPLACE(REPLACE(REPLACE(@template,
'{@column_list}', @column_list),
'{@schema_name}', @schema_name),
'{@table_name}', @table_name)
EXEC ( @sql )
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)