Oracle通过函数进行进制转化

十六进制转化为十进制:to_number()

SQL> select to_number(‘a‘,‘x‘) from dual;
TO_NUMBER(‘A‘,‘X‘)
------------------
                10

十进制转化为十六进制:to_char()

SQL> select to_char(10,‘xxx‘) from dual;
TO_CHAR(10,‘
------------
   a

二进制没有办法直接转化可以通过函数实现:

十进制转化为二进制

CREATE OR REPLACE FUNCTION NUMBER_TO_BIT(V_NUM NUMBER)
RETURN VARCHAR IS V_RTN VARCHAR(8);--注意返回列长度
  V_N1  NUMBER;
  V_N2  NUMBER;
BEGIN
V_N1 := V_NUM;
    LOOP
      V_N2  := MOD(V_N1, 2);
      V_N1  := ABS(TRUNC(V_N1 / 2)); --取商的绝对值
      V_RTN := TO_CHAR(V_N2) || V_RTN;
      EXIT WHEN V_N1 = 0;
    END LOOP;
--返回二进制长度
 SELECT lpad(V_RTN,8,0) --八位不足补0
    INTO   V_RTN
    FROM dual;
return V_RTN;
end;

二进制转化为十进制:

CREATE OR REPLACE FUNCTION BIT_TO_NUMBER(P_BIN IN VARCHAR2) RETURN NUMBER 
AS
  V_SQL VARCHAR2(30000) := ‘SELECT BIN_TO_NUM(‘;
  V_RETURN NUMBER;
BEGIN
  IF LENGTH(P_BIN) >= 256 THEN
    RAISE_APPLICATION_ERROR(-20001, ‘INPUT BIN TOO LONG!‘);
  END IF;
  IF LTRIM(P_BIN, ‘01‘) IS NOT NULL THEN
    RAISE_APPLICATION_ERROR(-20002, ‘INPUT STR IS NOT VALID BIN 
VALUE!‘);
  END IF;
  FOR I IN 1 .. LENGTH(P_BIN) LOOP
    V_SQL := V_SQL || SUBSTR(P_BIN, I, 1) || ‘,‘;
  END LOOP;
  V_SQL := RTRIM(V_SQL, ‘,‘) || ‘) FROM DUAL‘;
  EXECUTE IMMEDIATE V_SQL
    INTO V_RETURN;
  RETURN V_RETURN;
END;

创建函数同义词

create public synonym number_to_bit for number_to_bit;
grant execute on number_to_bit to public

十六转二和二转十六,则可以结合十转十六函数和二转十函数进行,这里不在额外举例。

ASCII码及ORACLE元数据转换函数:RAWTOHEX和HEXTORAW

SQL> select rawtohex(1) from dual;
RAWTOHEX(1)
------------
C102

SQL> select rawtohex(‘1‘) from dual;
RAWTOH
------
31

SQL> select rawtohex(‘a‘) from dual;
RAWTOH
------
61

SQL> select rawtohex(‘A‘) from dual;
RAWTOH
------
41

SQL> select hextoraw(‘A‘) from dual;
HE
--
0A

SQL> select hextoraw(‘1‘) from dual;
HE
--
01
时间: 2024-07-31 03:39:22

Oracle通过函数进行进制转化的相关文章

lqb 基础练习 十六进制转八进制 (字符串进行进制转化)

基础练习 十六进制转八进制 时间限制:1.0s   内存限制:512.0MB 问题描述 给定n个十六进制正整数,输出它们对应的八进制数. 输入格式 输入的第一行为一个正整数n (1<=n<=10). 接下来n行,每行一个由0~9.大写字母A~F组成的字符串,表示要转换的十六进制正整数,每个十六进制数长度不超过100000. 输出格式 输出n行,每行为输入对应的八进制正整数. [注意] 输入的十六进制数不会有前导0,比如012A. 输出的八进制数也不能有前导0. 样例输入 2 39 123ABC

更快地进行进制转换

更快地进行进制转换 本文主要针对二进制,八进制,十进制,十六进制中的一些转换提供一些技巧和思路,以加快进制转换的手算及心算速度. 十进制转换成其他进制 这里我举一个37.625(十进制)转换为二进制的例子来说明计算方法 分成两个步骤 步骤1 打表,以1为基础,向左不断乘以2,向右不断除以2 得出32 16 8 4 2 1 0.5 0.25 0.125 的表 步骤2 根据步骤1打出的表,每次取表中最大的数来进行减法运算,如果能被最大的数减去(结果大于等于0即能被减去)那么就减去该最大数,然后不断循

使用JavaScript进行进制转换

JS 是一个很神奇的语言,内制的的很多函数可以帮我们进行数(进)制转换: JS中可以直接使用16进制: var a = 0xff; //255 将任意进制字符串转换为十进制,如二进制,八进制,十六进制, 第二数数不写即为最常用的转换为整型十进制: parseInt("11", 2);   // 3   2进制转10进制 parseInt("77", 8);   // 63  8进制转10进制 parseInt("af", 16);  //175 

python3 第十章 - 如何进行进制转化

在计算器的世界里2进制是主流,而在人类的自然世界中10进制是主流,那么在这之间必然就会存在进制转化的问题.本章我们就来讲讲进制转化,也希望通过本章加深您对前些章所学知识的理解. 原理:先说说关于位权的概念,某进制计数制中各位数字符号所表示的数值表示该数字符号值乘以一个与数字符号有关的常数,该常数称为 "位权 " .位权的大小是以基数为底,数字符号所处的位置的序号为指数的整数次幂.十进制数的百位.十位.个位.十分位的权分别是10的2次方.10的1次方.10的0次方,10的-1次方.二进制

九度OJ题目1080:进制转换(java)使用BigInteger进行进制转换

题目描述: 将M进制的数X转换为N进制的数输出. 输入: 输入的第一行包括两个整数:M和N(2<=M,N<=36). 下面的一行输入一个数X,X是M进制的数,现在要求你将M进制的数X转换成N进制的数输出. 输出: 输出X的N进制表示的数. 样例输入: 16 10 F 样例输出: 15 提示: 输入时字母部分为大写,输出时为小写,并且有大数据. package a; import java.math.BigInteger; import java.util.*; public class Mai

python如何用format进行进制转换与如何删除进制前缀

10进行十进制,十六进制,八进制,二进制的转换:(#:保留进制前缀)对于带着进制前缀的,如"0x"“0o”“0b”,可以直接在后面加上’x’‘o’'b’进行删除:其他的一些小技巧:format(num, ",")快速分割千分位数字是补全多少位,^居中 >右对齐 <左对齐*^10Unexpected text node: '&ThickSpace;'Unexpected text node: '&ThickSpace;'?一共10位,居中,

C语言编写进制转化

p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 12.0px "PingFang SC"; color: #454545 } p.p2 { margin: 0.0px 0.0px 0.0px 0.0px; font: 12.0px Helvetica; color: #454545 } span.s1 { font: 12.0px Helvetica } span.s2 { font: 12.0px "PingFang SC&quo

Java Integer 进制转化的实现(附源码),对模与补码的理解

1.toBinaryString方法的实现 1 public static String toBinaryString(int i) { 2 return toUnsignedString0(i, 1); 3 } 4 private static String toUnsignedString0(int val, int shift) { 5 // assert shift > 0 && shift <=5 : "Illegal shift value";

计算机基础知识_进制转化

进制转化 一.任何一个进制转化为10进制的方式 156的十进制可以看做1*10^2 + 5*10^1  +   6*10^0 首先我们看一下156 ,平方,次方等等都是根据后面有多少位决定的,如果用计算机计算,则正好是156 33是一个八进制可以看做3*8^1+3*8^0 次方  换算出来就是10进制 如果你本身是x进制,那么你的数字就看做  num * x^位数  比如我有一个16进制的数字,转为10进制 16进制在计算机中表示方法: 1 2 3 4 5 6 7 8 9 a b c d e f