本文共 1596 字,大约阅读时间需要 5 分钟。
我们知道通过to_char和to_number函数可以实现10进制和16进制之间的转换,通过函数bin_to_num进行2进制到10进制的转换。这个在的站点上也有类似的介绍。
今日收集,整理一个更为通用的Decimal, Binary, Octal and Hexidecimal number之间的转换函数包,欢迎大家
测试效果如下:
SQL> desc num_demo
FUNCTION BIN_TO_DEC RETURNS NUMBER参数名称 类型 输入/输出默认值?------------------------------ ----------------------- ------ --------BINVAL CHAR INFUNCTION DEC_TO_BIN RETURNS VARCHAR2参数名称 类型 输入/输出默认值?------------------------------ ----------------------- ------ --------N NUMBER INFUNCTION DEC_TO_HEX RETURNS VARCHAR2参数名称 类型 输入/输出默认值?------------------------------ ----------------------- ------ --------N NUMBER INFUNCTION DEC_TO_OCT RETURNS VARCHAR2参数名称 类型 输入/输出默认值?------------------------------ ----------------------- ------ --------N NUMBER INFUNCTION HEX_TO_DEC RETURNS NUMBER参数名称 类型 输入/输出默认值?------------------------------ ----------------------- ------ --------HEXVAL CHAR INFUNCTION OCT_TO_DEC RETURNS NUMBER参数名称 类型 输入/输出默认值?------------------------------ ----------------------- ------ --------OCTVAL CHAR INSQL>
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>
转载地址:http://kqbso.baihongyu.com/