十进制/十八进制的互转换(此方法应用于所有进制与10进制的转换)

本文介绍了一种使用SQL编程实现的十进制与十八进制相互转换的方法。其中包括将十进制数转换为十八进制字符串的函数F_int18,以及将十八进制字符串转换回十进制数的函数F_int10。通过具体的SQL函数代码示例展示了如何进行这两种转换。
------十进制转换为十八进制
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行)

*/
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值