IEEE 16进制浮点数转化为10进制的自定义函数

博客详细介绍了如何编写一个自定义函数,将IEEE标准下的16进制浮点数转换为10进制数值。内容包括必要的辅助函数,如16进制到2进制的转换,通过一系列计算过程完成复杂的浮点数换算。
摘要由CSDN通过智能技术生成
    这个问题首先要搞清楚16进制浮点数的表示方法,根据IEEE的标准,分为32位和64位两种,参数分别如下:
 
 

 符号位

 指数位

 尾数位

 指数偏移量

 32位

1[31]

8[23-30]

23[0-22]

127

 64位

 1[63]

 11[52-62]

 52[0-51]

 1023

    其次,要先准备几个函数,如16进制转成2进制的函数等。这里一起列出

 

 /*    16进制数转化为2进制数的函数    */
CREATE function Hex2Bin(
@h varchar(50)
)
returns varchar(200)
as
 /*    16进制数转化为2进制数的函数    */
 /* 版本:   1.0   */
 /* 作者: Haiwer   */
 /* 版权所有    */
begin
 -- 去掉多余的 0X
 if left(@h,2)='0X'
  set @h=right(@h,len(@h)-2)
    declare @r varchar(100)
 set @r=''
    declare @i int
    set &#
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值