ORACLE 36进制和10进制,互相转换函数

第一部分

--36转10进制

create or replace function f_36to10 (str varcharreturn int  is

  returnValue int;
  str36     varchar(36);
  subWork   varchar(1);
  workIndex   int;
  len     int;
  i       int;

begin

  returnValue:= 0;
  str36 := '123456789ABCDEFGHIJKLMNOPQRSTUVWSYZ';
  i := 1;
  len := length(trim(str));
  
  while i <= len loop
    subWork := SUBSTR(str, i, 1);
    workIndex := instrstr36,subWork,1,1);
    returnValue := returnValue + (workIndex * power(36, len-i));
    i := i + 1;
  end loop;

  return  returnValue;
  
end f_36to10;

 

第二部分

--10转36进制

create or replace function f_10to36(intreturn varchar is

  ret varchar2(8);
  var_m int;
  var_s int;
  
begin

  ret := '';
  var_s := i;
  while var_s >= 36 loop
    var_m := mod(var_s, 36);
    if var_m < 10 then
     ret := to_char(var_m|| ret;
    else
    ret := chr(var_m - 10 97|| ret;
      end if;
    var_s := trunc(var_s / 36);
  end loop;
  if var_s > or (var_s = and ret = '') then
    if var_s < 10 then
     ret := to_char(var_s|| ret;
    else
     ret := chr(var_s - 10 97|| ret;
    end if;
  end if;
  
  return UPPER(ret);--lpad(ret, 8'0');
  
end f_10to36;

 

另外一个方法,链接:http://www.cnblogs.com/jak-black/archive/2010/09/25/1834617.html

转载于:https://www.cnblogs.com/zzjhn/p/5057106.html

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值