varbinary to varchar без master.dbo.fn_varbintohexstr - PullRequest
4 голосов
/ 09 июля 2011

Есть ли способ конвертировать varbinary в строку ASCII varchar (base64, md5, sha1 - неважно) без функции master.dbo.fn_varbintohexstr на MS SQL Server 2005? Потому что его нельзя использовать внутри вычисляемого столбца.

CONVERT и CAST возвращают не-ASCII строки.

Спасибо,

Денис.

1 Ответ

4 голосов
/ 10 июля 2011

Для md5 и sha1 вы можете использовать хешбайт .Чтобы получить base64, вы можете создать udf, который выполняет преобразование, и использовать его в вычисляемом столбце.

Функция BinToBase64:

create function BinToBase64(@Bin varbinary(max)) returns varchar(max) as
begin
  return CAST(N'' AS XML).value('xs:base64Binary(xs:hexBinary(sql:variable("@Bin")))', 'VARCHAR(MAX)')
end

Функция BinToHexString:

create function BinToHexString(@Bin varbinary(max)) returns varchar(max) as
begin
  return '0x' + cast('' as xml).value('xs:hexBinary(sql:variable("@Bin") )', 'varchar(max)'); 
end

Используйте это так:

create table TestTable 
(
  Col1 varbinary(max), 
  Col2 as dbo.BinToHexString(hashbytes('MD5', Col1)),
  Col3 as dbo.BinToHexString(hashbytes('SHA1', Col1)),
  Col4 as dbo.BinToBase64(Col1),
)
insert into TestTable values (12345)

select *
from TestTable

Уникальный столбец varbinary ограничений с использованием хеш-байтов и столбец уникального идентификатора

create table TestTable 
(
  ID uniqueidentifier default(newid()),
  Col1 varbinary(max), 
  Col2 as coalesce(hashbytes('MD5', Col1), cast(ID as varbinary(8000))) persisted
)

create unique index IX_TestTable_Col2 on TestTable(Col2)
...