------十进制转换为十八进制
createfunctionF_int18(@numint)
returnsnvarchar(50)
as
begin
if@num=0
return'0'
declare@snvarchar(50)
set@s=''
while@num>0
select@s=substring('0123456789ABCDEFHG',@num%18+1,1)+@s,@num=@num/18
return@s
end
go
----------十八进制转换为十进制
createfunctionF_int10(@snvarchar(50))
returnsint
as
begin
declare@iint,@s2nvarchar(2),@numint
select@i=len(@s),@num=0
while@i>0
select@s2=substring(reverse(@s),@i,1),
@num=power(18,@i-1)*(charindex(@s2,'0123456789ABCDEFHG')-1)+@num,
@i=@i-1
return@num
end
go

selectdbo.F_int18(9999)
selectdbo.F_int10('1CF9')

/**//*
--------------------------------------------------
1CF9
(所影响的行数为1行)

-----------
9999
(所影响的行数为1行)
*/
本文介绍了一种使用SQL编程实现的十进制与十八进制相互转换的方法。其中包括将十进制数转换为十八进制字符串的函数F_int18,以及将十八进制字符串转换回十进制数的函数F_int10。通过具体的SQL函数代码示例展示了如何进行这两种转换。
6275

被折叠的 条评论
为什么被折叠?



