On this page
8.2. 货币类型
money
类型以固定的小数精度存储货币金额;参见Table 8.3。小数精度由数据库的lc_monetary设置确定。表中显示的范围假设有两个小数位。接受各种格式的 Importing,包括整数和浮点 Literals,以及典型的货币格式,例如'$1,000.00'
。输出通常采用后一种形式,但取决于语言环境。
表 8.3. 货币类型
Name | Storage Size | Description | Range |
---|---|---|---|
money |
8 bytes | currency amount | -92233720368547758.08 至 92233720368547758.07 |
由于此数据类型的输出是对语言环境敏感的,因此将money
数据加载到具有不同设置lc_monetary
的数据库中可能不起作用。为避免出现问题,在将转储还原到新数据库之前,请确保lc_monetary
具有与转储数据库中相同或相等的值。
numeric
,int
和bigint
数据类型的值可以强制转换为money
。可以通过先转换为numeric
来完成real
和double precision
数据类型的转换,例如:
SELECT '12.34'::float8::numeric::money;
但是,不建议这样做。由于存在四舍五入的错误,不应使用浮点数来处理资金。
可以将money
的值强制转换为numeric
,而不会损失精度。转换为其他类型可能会失去精度,并且还必须分两个阶段完成:
SELECT '52093.89'::money::numeric::float8;
money
值除以整数值的过程是将小数部分截断为零。要获得四舍五入的结果,请除以浮点值,或将money
值转换为numeric
,然后除以,然后再返回为money
。 (最好避免使用后者,以免造成精度损失.)将money
值除以另一个money
值时,结果为double precision
(即纯数字,而不是金钱);货币单位在部门中彼此抵消。