Microsoft SQL 2016解码Base64列
我需要帮助来解码数据库中的Base64密码列。当我将单列内容复制到https://www.base64decode.org/中时,它可以完美地解码。在本专栏中,我只需要在大约7000行上执行此操作。我们非常感谢您的帮助。
解决方案
您可以使用(source):
declare @source varbinary(max), @encoded varchar(max), @decoded varbinary(max)
set @source = convert(varbinary(max), 'Hello Base64')
set @encoded = cast('' as xml).value('xs:base64Binary(sql:variable("@source"))', 'varchar(max)') set @decoded = cast('' as xml).value('xs:base64Binary(sql:variable("@encoded"))', 'varbinary(max)')
select convert(varchar(max), @source) as source_varchar, @source as source_binary, @encoded as encoded, @decoded as decoded_binary, convert(varchar(max), @decoded) as decoded_varchar
.但是,为此创建一个函数,则:
create function fnDecodeBase64 (@encoded as varchar(max))
returns varchar(max)
as
begin
declare @decoded varchar(max)
set @decoded = cast('' as xml).value('xs:base64Binary(sql:variable("@encoded"))', 'varbinary(max)')
return @decoded
end
因此,您可以使用:
select dbo.fnDecodeBase64(some_column) from Some_Table
您还可以使用:
select convert(varchar(max),cast(N'' as xml).value('xs:base64Binary(sql:column("t.SomeColumn"))', 'varbinary(max)')) as converted_64_column
from SomeTable as t
关键字:sql:column
起作用
相关文章