本文介绍了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
起作用
这篇关于Microsoft SQL 2016解码Base64列的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持!