且构网

分享程序员开发的那些事...
且构网 - 分享程序员编程开发的那些事

Oracle 内部2,8,10,16进制转换函数包

更新时间:2022-08-22 16:32:10

我们知道通过to_char和to_number函数可以实现10进制和16进制之间的转换,通过函数bin_to_num进行2进制到10进制的转换。这个在eygle的站点上也有类似的介绍。

今日收集,整理一个更为通用的Decimal, Binary, Octal and Hexidecimal number之间的转换函数包,欢迎大家下载使用

测试效果如下:


SQL> desc num_demo
FUNCTION BIN_TO_DEC RETURNS NUMBER
参数名称 类型 输入/输出默认值?
------------------------------ ----------------------- ------ --------
BINVAL CHAR IN
FUNCTION DEC_TO_BIN RETURNS VARCHAR2
参数名称 类型 输入/输出默认值?
------------------------------ ----------------------- ------ --------
N NUMBER IN
FUNCTION DEC_TO_HEX RETURNS VARCHAR2
参数名称 类型 输入/输出默认值?
------------------------------ ----------------------- ------ --------
N NUMBER IN
FUNCTION DEC_TO_OCT RETURNS VARCHAR2
参数名称 类型 输入/输出默认值?
------------------------------ ----------------------- ------ --------
N NUMBER IN
FUNCTION HEX_TO_DEC RETURNS NUMBER
参数名称 类型 输入/输出默认值?
------------------------------ ----------------------- ------ --------
HEXVAL CHAR IN
FUNCTION OCT_TO_DEC RETURNS NUMBER
参数名称 类型 输入/输出默认值?
------------------------------ ----------------------- ------ --------
OCTVAL CHAR IN

SQL>


SQL> select num_demo.dec_to_bin(100) from dual;

1100100

已选择 1 行。

SQL> select num_demo.bin_to_dec('1100100') from dual;

100
已选择 1 行。

SQL> select num_demo.dec_to_oct(16) from dual;

20

已选择 1 行。

SQL> select num_demo.oct_to_dec(20) from dual;

16
已选择 1 行。

SQL> select num_demo.hex_to_dec(65536) from dual;

10000

已选择 1 行。


SQL> select num_demo.hex_to_dec('FF') from dual;

255

已选择 1 行。

SQL> select num_demo.dec_to_hex(255) from dual;

FF

已选择 1 行。

SQL> select num_demo.hex_to_dec('FFFF') from dual;

65535

已选择 1 行。

SQL> select num_demo.dec_to_hex( 65535) from dual;

FFFF

已选择 1 行。

SQL>