Skip to content

8.2. 货币类型#

money类型存储具有固定小数精度的货币金额;请参见表 8.3。小数精度由数据库的lc_monetary设置决定。表中显示的范围假定有两个小数位。可以接受多种格式的输入,包括整数和浮点文字,以及典型的货币格式,例如'$1,000.00'。输出通常采用后一种形式,但取决于区域设置。

表 8.3. 货币类型

名称存储大小说明范围
money8 字节货币金额-92233720368547758.08 至 +92233720368547758.07

由于此数据类型的输出对区域设置敏感,因此可能无法将money数据加载到具有不同lc_monetary设置的数据库中。为避免出现问题,在将转储还原到新数据库之前,请确保lc_monetary具有与转储数据库相同或等效的值。

可以将numericintbigint数据类型的数值强制转换为money。要从realdouble precision数据类型进行转换,可以先强制转换为numeric,例如

SELECT '12.34'::float8::numeric::money;

但是,不建议这样做。由于存在舍入误差的可能性,不应使用浮点数来处理货币。

可以将money值强制转换为numeric,而不会损失精度。转换为其他类型可能会损失精度,并且还必须分两个阶段进行

SELECT '52093.89'::money::numeric::float8;

money值除以整数值时,会截断小数部分并朝 0 方向舍入。要获得舍入结果,请除以浮点值,或在除法之前将money值强制转换为numeric,并在之后再强制转换为money。(后者更可取,以避免精度损失的风险。)当将money值除以另一个money值时,结果为double precision(即纯数字,不是货币);货币单位在除法中相互抵消。