#BIN_TO_NUM

bin_to_num
BIN_TO_NUM ( expr , )

BIN_TO_NUM函数用于实现二进制向十进制的转换,将一个或多个expr组合表示的二进制位向量串转换成与其等效的数值,返回一个NUMBER类型的数据。该函数不支持向量化计算。

每一个expr表示位向量中的一个位,其值可以为任何数值型,或可隐式转换为NUMBER类型的字符型数据。

本函数支持最多输入65535个expr作为参数,但计算的数值超过number表示范围则报错,且所有expr的值都必须为0/1,或进行取整后为0/1,否则报错。取整规则为:

  1. 如果expr为FLOAT/DOUBLE类型,函数对其进行奇进偶舍取整(例如:1.5->2,0.5->0)。
  2. 对于其他类型,函数进行去掉小数位取整(例如:1.3->1,1.6->1)。

示例(HEAP表)

--将二进制位向量串11转换为十进制3
SELECT BIN_TO_NUM(1,1) res FROM DUAL;
RES
-----------
3

--将二进制位向量串1101转换为十进制13
SELECT BIN_TO_NUM(b'1',1,0,1) res FROM DUAL;
RES
-----------
13

--创建bt_table_bin_to_num表,包含多个浮点型字段
CREATE TABLE bt_table_bin_to_num(c1 DOUBLE, c2 DOUBLE, c3 DOUBLE, c4 DOUBLE);
INSERT INTO bt_table_bin_to_num VALUES(0.3,0.8,1.3,1.8);

--对于NUMBER数据,函数按去小数位取整后进行十进制转换,对于浮点型小数,函数按四舍五入取整后进行十进制转换
SELECT BIN_TO_NUM(0.3) "0.3", BIN_TO_NUM(c1) "d0.3", 
BIN_TO_NUM(0.8) "0.8", BIN_TO_NUM(c2) "d0.8", 
BIN_TO_NUM(1.3) "1.3", BIN_TO_NUM(c3) "d1.3"
FROM bt_table_bin_to_num;
        0.3        d0.3         0.8        d0.8         1.3        d1.3 
----------- ----------- ----------- ----------- ----------- ----------- 
          0           0           0           1           1           1

--对于NUMBER数据,函数按去小数位取整为1后进行十进制转换
SELECT BIN_TO_NUM(1.8) res FROM DUAL;
RES
-----------
1

--c4字段按四舍五入取整为2后进行十进制转换,导致报错
SELECT BIN_TO_NUM(c4) res FROM bt_table_bin_to_num;
[1:19]YAS-06001 the value of parameter expression is invalid, the value of the expression must be 0 or 1
pdf-btn 下载文档
copy-btn 复制链接