2025年9月25日: PostgreSQL 18 发布!
支持的版本: 当前 (18) / 17 / 16 / 15 / 14 / 13
开发版本: devel
不支持的版本: 12 / 11 / 10 / 9.6 / 9.5 / 9.4 / 9.3 / 9.2 / 9.1 / 9.0 / 8.4 / 8.3 / 8.2 / 8.1 / 8.0 / 7.4 / 7.3 / 7.2 / 7.1

8.2. 货币类型 #

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

表 8.3. 货币类型

名称 存储大小 描述 范围
money 8 字节 货币金额 -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 值时,会进行截断小数部分(向零取整)的操作。要获得舍入结果,请除以浮点值,或先将 money 值转换为 numeric,然后再转换回 money。(后者更可取,以避免精度丢失的风险。)当 money 值除以另一个 money 值时,结果是 double precision(即,一个纯数字,不是货币);在除法中,货币单位会相互抵消。

提交更正

如果您在文档中发现任何不正确的内容、与您对特定功能的实际体验不符的内容或需要进一步说明的内容,请使用此表单来报告文档问题。