免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 3051 | 回复: 2
打印 上一主题 下一主题

请教:informix十六进制转十进制函数 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2006-02-23 19:35 |只看该作者 |倒序浏览
各位大哥:


informix十六进制转十进制函数;在线等待,非常急!!!!!!!!!!!!!!!!!11

论坛徽章:
0
2 [报告]
发表于 2006-02-24 08:30 |只看该作者
写个存储过程去实现。

论坛徽章:
0
3 [报告]
发表于 2006-02-24 10:45 |只看该作者
闲着 给你写个。IDS7.31上测试通过。

create procedure dec(s1 varchar(255) )
  returning decimal(20,0) ;

  define ss varchar(255);
  define tt char(1);
  define result decimal(20,0);
  define i integer;

  let ss = lower(s1);
  let ss = trim( both from ss );
  if  ( substr( ss, 1,1 ) = '0' and substr( ss,2,1 ) ='x' )
  then
     let ss = substr( ss,3 );
  end if

  let result = 0;

  for  i =1  to  length ( ss )
        let tt = substr( ss,i,1);
        let result = result * 16 +
                decode( tt,
                        'a',10,'b',11,
                        'c',12,'d',13,
                        'e',14,'f',15,
                         tt+0);
  end for
  return result ;
end procedure;

[ 本帖最后由 wenlq 于 2006-2-24 11:06 编辑 ]
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP