Аналогично этому вопросу (сервер Sql преобразует целое число в двоичную строку, но Вместо этого я хотел бы преобразовать varbinary(16) в его текстовую версию.
Я делаю что-то трагически неправильное, о чем свидетельствуют результаты моего кода.
create function GetGuidBinaryString (@value varbinary(16))
returns varchar(128)
as
begin
declare @vsresult varchar(128)
declare @inti int
select @inti = 128, @vsresult = ''
while @inti>0
begin
select @vsresult=convert(char(1), @value % 2)+@vsresult
select @value = convert(int, (@value / 2)), @inti=@inti-1
end
return @vsresult
end
create table #values (binvalue varchar(128))
delete from #values
declare @intcount int
select @intcount = 0
while @intcount < 100
begin
insert into #values select dbo.GetGuidBinaryString(convert(varbinary(16),convert(bigint,2147483640) + @intcount))
select @intcount = @intcount+1
end
select * from #values
Возможно, я выполняю какое-то неявное преобразование в функции, поскольку функция правильно работает только для положительных целых чисел.