• 软件测试技术
  • 软件测试博客
  • 软件测试视频
  • 开源软件测试技术
  • 软件测试论坛
  • 软件测试沙龙
  • 软件测试资料下载
  • 软件测试杂志
  • 软件测试人才招聘
    暂时没有公告

字号: | 推荐给好友 上一篇 | 下一篇

ORACLE中用一条SQL实现其它进制到十进制的转换

发布: 2008-2-22 15:17 | 作者: 叶正盛 | 来源: http://dev.csdn.net | 查看: 18次 | 进入软件测试论坛讨论

领测软件测试网 对其它进制可以根据例子将power的底数改成相应的进制就可以了。

  本文只是一个例子,大家可以把它封装成一个通用函数进行实用。

  大家在试的时候将里面相应的其它进制的数值换成自己的数据就可以了(有多处)。

 

  -----二进制转换十进制-----------------
  select sum(data1)
    from (select substr('1101', rownum, 1) * power(2, length('1101') - rownum) data1
            from dual
          connect by rownum <= length('1101'))

  -----八进制转换十进制-----------------
  select sum(data1)
    from (select substr('1101', rownum, 1) * power(8, length('1101') - rownum) data1
            from dual
          connect by rownum <= length('1101'))

  -----十六进制转换十进制-----------------
  select sum(data1)
    from (select (CASE upper(substr('2D', rownum, 1))
                   WHEN 'A' THEN '10'
                   WHEN 'B' THEN '11'
                   WHEN 'C' THEN '12'
                   WHEN 'D' THEN '13'
                   WHEN 'E' THEN '14'
                   WHEN 'F' THEN '15'
                   ELSE substr('2D', rownum, 1)
                 END) * power(16, length('2D') - rownum) data1
            from dual
          connect by rownum <= length('2D'))

文章来源于领测软件测试网 https://www.ltesting.net/


关于领测软件测试网 | 领测软件测试网合作伙伴 | 广告服务 | 投稿指南 | 联系我们 | 网站地图 | 友情链接
版权所有(C) 2003-2010 TestAge(领测软件测试网)|领测国际科技(北京)有限公司|软件测试工程师培训网 All Rights Reserved
北京市海淀区中关村南大街9号北京理工科技大厦1402室 京ICP备2023014753号-2
技术支持和业务联系:info@testage.com.cn 电话:010-51297073

软件测试 | 领测国际ISTQBISTQB官网TMMiTMMi认证国际软件测试工程师认证领测软件测试网