Поделиться через


HASHBYTES (Transact-SQL)

Возвращает хэш MD2, MD4, MD5, SHA1 или SHA2 входного значения.

Значок ссылки на раздел Синтаксические обозначения Transact-SQL

Синтаксис

HASHBYTES ( '<algorithm>', { @input | 'input' } ) 

<algorithm>::= MD2 | MD4 | MD5 | SHA | SHA1 | SHA2_256 | SHA2_512 

Аргументы

  • '<algorithm>'
    Указывает используемый алгоритм хэширования. Этот аргумент обязателен и не имеет значения по умолчанию. Указание одинарных кавычек (") также обязательно.

  • @input
    Указывает переменную, содержащую хэшируемые данные. Аргумент @input имеет тип varchar, nvarchar или varbinary.

  • ' input '
    Указывает хэшируемую строку.

Возвращаемое значение

varbinary (не более 8 000 байт)

Замечания

Допустимый размер входных значений ограничен 8000 байт. Выходные данные соответствуют стандарту алгоритма: 128 бит (16 байт) для MD2, MD4 и MD5; 160 бит (20 байт) для SHA и SHA1; 256 бит (32 байта) для SHA2_256 и 512 бит (64 байта) для SHA2_512

Примеры

В следующем примере возвращается SHA1 хэш данных nvarchar, хранящихся в переменной @HashThis.

DECLARE @HashThis nvarchar(4000);
SELECT @HashThis = CONVERT(nvarchar(4000),'dslfdkjLK85kldhnv$n000#knf');
SELECT HASHBYTES('SHA1', @HashThis);
GO

См. также

Основные понятия

Выбор алгоритма шифрования