sql >> Databasteknik >  >> RDS >> Sqlserver

Beräkna hash eller kontrollsumma för en tabell i SQL Server

Du kan använda CHECKSUM_AGG . Det krävs bara ett enda argument, så du kan göra CHECKSUM_AGG(CHECKSUM(*)) - men det här fungerar inte för din XML-datatyp, så du måste tillgripa dynamisk SQL.

Du kan generera kolumnlistan dynamiskt från INFORMATION_SCHEMA.COLUMNS och infoga sedan int i en mall:

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 )


  1. Hur man grupperar hierarkiska relationer i SQL Server

  2. Välj data med max datumordning efter ett annat fält

  3. SQLSTATE[HY000] [2002] Ett anslutningsförsök misslyckades.. - Vid försök att ansluta från lokal till fjärrserver

  4. Analysfel:syntaxfel, oväntat 'mysql_query' (T_STRING) i