【PostgreSQL】从零开始:(十七)数据类型-货币类型

货币类型

PostgreSQL支持多种类型的货币数据,包括:

money:这是最常用的货币类型。它存储一个带有两位小数的货币金额,以美元为单位。例如, '$10.00' 或 '€20.00'。(16 / 15 / 14 / 13 / 12版本支持)

名字 存储大小 描述 范围
money 8 字节 货币金额 -92233720368547758.08 至 +92233720368547758.07

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

和数据类型的值可以转换,可以通过强制转换完成从 numeric,int,bigint,money,real,double precision 数据类型转换

sql 复制代码
SELECT '12.34'::float8::numeric::money;

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

可以在不损失精度的情况下强制转换为值。转换为其他类型可能会失去精度,并且还必须分两个阶段完成:money numeric

sql 复制代码
SELECT '52093.89'::money::numeric::float8;

numeric:这是一种精确的货币类型,它能够存储任意精度的货币金额。它适用于需要精确计算的场景。

decimal:与numeric类型类似,decimal也是一种精确的货币类型,可以存储任意精度的货币金额。

real:这是一种单精度浮点数类型,它可以用来存储货币金额。然而,由于浮点数精度的限制,不建议在商业应用中使用real类型来存储货币金额。

double precision:这是一种双精度浮点数类型,与real类型类似,也不建议在商业应用中使用double precision类型来存储货币金额。

在使用这些货币类型时,可以进行各种数学运算,比较和聚合操作。值得注意的是,在进行数学运算时,应使用适当的四舍五入规则来处理货币金额的精度。

相关推荐
力学与人工智能5 分钟前
“高雷诺数湍流数据库的构建及湍流机器学习集成研究”湍流重大研究计划集成项目顺利结题
数据库·人工智能·机器学习·高雷诺数·湍流·重大研究计划·项目结题
TDengine (老段)8 分钟前
TDengine 脱敏函数用户手册
大数据·服务器·数据库·物联网·时序数据库·iot·tdengine
weixin_4462608515 分钟前
[特殊字符] 使用 PageIndex 提升文档检索效率,告别向量数据库的局限!
数据库
TsengOnce28 分钟前
Docker 安装达梦8数据库-5步成功
java·数据库
存在的五月雨37 分钟前
Mysql 函数
数据库·mysql
m0_5613596739 分钟前
使用PyTorch构建你的第一个神经网络
jvm·数据库·python
前方一片光明44 分钟前
SQL SERVER—将所有表的cjsj字段改为datetime2(0),去掉毫秒
数据库
老邓计算机毕设1 小时前
SSM医院疫情管理系统e3oxi(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面
数据库·医疗信息化·ssm 框架·医院疫情管理系统
diediedei1 小时前
持续集成/持续部署(CI/CD) for Python
jvm·数据库·python
砚边数影1 小时前
决策树实战:基于 KingbaseES 的鸢尾花分类 —— 模型可视化输出
java·数据库·决策树·机器学习·分类·金仓数据库