Oracle 10进制转36进制

时间:2015-05-13 10:07:23   收藏:0   阅读:180

CREATE OR REPLACE FUNCTION IDFMS.func_dec236 (parm IN INT DEFAULT 0)
   RETURN VARCHAR2
IS
   /*
   10进制数转36进制数
   */
   src   VARCHAR2 (36) := ‘0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ‘; --改成其它字符串,就是任意进制
   LEN   INT;
   res   VARCHAR2 (10) := ‘‘;
   tmp   INT;
   val   INT;
BEGIN
   tmp := parm;
   len := LENGTH (src);

   WHILE (tmp >= 36)
   LOOP
      val := MOD (tmp, len);
      res := SUBSTR (src, val + 1, 1) || res;
      tmp := TRUNC (tmp / len);
   END LOOP;

   IF (tmp >= 0)
   THEN
      res := SUBSTR (src, tmp + 1, 1) || res;
   END IF;

   RETURN res;
END;
/

原文:http://www.cnblogs.com/baishahe/p/4499336.html

评论(0
© 2014 bubuko.com 版权所有 - 联系我们:wmxa8@hotmail.com
打开技术之扣,分享程序人生!