DECIMAL 类型

适用于:check marked yes Databricks SQL check marked yes Databricks Runtime

表示具有特定最大精度和固定位数的数字。

语法

{ DECIMAL | DEC | NUMERIC } [ (  p [ , s ] ) ]

p:数字 1 到 38 之间的可选最大精度(数字总位数)。 默认值为 10。 s:数字 0 到 p 之间的可选位数。 小数点右边的数字位数。 默认值为 0。

限制

数字范围:

  • -1Ep + 1 到 -1E-s
  • 0
  • +1E-s 到 +1Ep - 1

例如,DECIMAL (5, 2) 的范围为:-999.99 到 999.99。

文本

decimal_digits { [ BD ] | [ exponent BD ] }
| digit [ ... ] [ exponent ] BD

decimal_digits:
[ + | - ] { digit [ ... ] . [ digit [ ... ] ]
            | . digit [ ... ] }

exponent:
E [ + | - ] digit [ ... ]

digit:0 到 9 的任意数字。

BD 后缀和 E 指数不区分大小写。

示例

> SELECT +1BD;
  1

> SELECT 5E3BD;
  5000

> SELECT 5.321E2BD;
  532.1

> SELECT -6.45
  -6.45

> SELECT typeof(6.45);
  DECIMAL(3,2)

> SELECT CAST(5.345 AS DECIMAL(3, 2));
  5.35

> SELECT typeof(CAST(5.345 AS DECIMAL));
  DECIMAL(10, 0)

> SELECT typeof(CAST(5.345 AS DECIMAL(2)));
  DECIMAL(2, 0)