money
类型存储具有固定小数精度的货币金额;请参见表 8.3。小数精度由数据库的lc_monetary 设置决定。表中显示的范围假定有两位小数。输入接受多种格式,包括整数和浮点文字,以及典型的货币格式,例如 '$1,000.00'
。输出通常采用后一种形式,但取决于区域设置。
表 8.3. 货币类型
名称 | 存储大小 | 描述 | 范围 |
---|---|---|---|
money |
8 字节 | 货币金额 | -92233720368547758.08 到 +92233720368547758.07 |
由于此数据类型的输出对区域设置敏感,因此将 money
数据加载到具有不同 lc_monetary
设置的数据库中可能无法工作。为避免出现问题,在将转储还原到新数据库之前,请确保 lc_monetary
的值与转储的数据库中的值相同或等效。
numeric
、int
和 bigint
数据类型的值可以强制转换为 money
。real
和 double precision
数据类型的转换可以通过首先强制转换为 numeric
来完成,例如:
SELECT '12.34'::float8::numeric::money;
但是,不建议这样做。由于存在舍入误差的可能性,因此不应使用浮点数来处理货币。
money
值可以强制转换为 numeric
而不会损失精度。转换为其他类型可能会损失精度,并且也必须分两个阶段完成:
SELECT '52093.89'::money::numeric::float8;
一个 money
值除以一个整数值时,会截断小数部分,使其趋向于零。要获得四舍五入的结果,请除以一个浮点值,或者在除法之前将 money
值强制转换为 numeric
,然后再将其强制转换为 money
。(后者更可取,以避免冒精度损失的风险。)当一个 money
值除以另一个 money
值时,结果是 double precision
(即,一个纯数字,而不是货币);货币单位在除法中相互抵消。
如果您发现文档中的任何内容不正确、与您使用特定功能的经验不符或需要进一步澄清,请使用此表格报告文档问题。