2024年9月26日:PostgreSQL 17 发布!
支持的版本:当前 (17) / 16 / 15 / 14 / 13 / 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。可以先转换为numeric,然后从realdouble precision数据类型进行转换,例如

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

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

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

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

money值除以整数值时,将对小数部分进行截断至零。要获得四舍五入的结果,请除以浮点值,或在除法之前将money值转换为numeric,然后转换回money。(后者更可取,可以避免精度损失的风险。)当money值除以另一个money值时,结果为double precision(即纯数字,而不是货币);货币单位在除法中相互抵消。

提交更正

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