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

news/2024/7/9 19:44:17 标签: postgresql, 数据库

货币类型

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

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

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

由于此数据类型的输出区分区域设置,因此将数据加载到具有不同设置 的数据库中可能不起作用。为避免出现问题,在将转储还原到新数据库之前,请确保具有lc_monetary相同或等效的值。
和数据类型的值可以转换,可以通过强制转换完成从 numeric,int,bigint,money,real,double precision 数据类型转换

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

但是,不建议这样做。由于可能存在舍入错误,因此不应使用浮点数来处理资金。
可以在不损失精度的情况下强制转换为值。转换为其他类型可能会失去精度,并且还必须分两个阶段完成:money numeric

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

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

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

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

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

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


http://www.niftyadmin.cn/n/5274936.html

相关文章

[C++]——学习模板

了解模板——初阶 前言:一、模板1.1 什么是模板1.2 模板的概念1.3 模板可以做什么1.4 泛型模板 二、函数模板2.1 函数模板概念和格式2.2 函数模板原理2.3 函数模板实例化2.3.1 隐式实例化2.3.2 显式实例化 2.4 模板参数的匹配原则2.5 函数模板声明定义分离 三、类模…

【Docker】基础篇

文章目录 Docker为什么出现容器和虚拟机关于虚拟机关于Docker二者区别: Docker的基本组成相关概念-镜像,容器,仓库安装Docker卸载docker阿里云镜像加速docker run的原理**为什么容器比虚拟机快**Docker的常用命令1.帮助命令2.镜像相关命令3.容…

bash数组的用法

一、单纯数组 #!/usr/bin/env bash#1、定义一个空数组 my_array()#2、增。使用 运算符将元素添加到数组的末尾 my_array("value1") my_array("value2") my_array("value3")#3、增。还可以使用一行的方式一次性添加多个元素到数组 my_array(&qu…

案例073:基于微信小程序的智慧旅游平台开发

文末获取源码 开发语言:Java 框架:SSM JDK版本:JDK1.8 数据库:mysql 5.7 开发软件:eclipse/myeclipse/idea Maven包:Maven3.5.4 小程序框架:uniapp 小程序开发软件:HBuilder X 小程序…

Flask重定向后无效果前端无跳转无反应问题

在网上搜了一下并没有什么好的解决方案,有的话也只是告诉你如何修改代码,并没有讲明白其中的原理以及导致问题的核心,因此特意去了解了一下HTTP的规范找到了答案 问题说明 问题出现的流程大致都是前端发送Ajax请求给后端,进行一些…

原生微信小程序-使用 阿里字体图标 详解

步骤一 1、打开阿里巴巴矢量图标库 网址:iconfont-阿里巴巴矢量图标库 2、搜索字体图标,鼠标悬浮点击添加入库 3、按如下步骤添加到自己的项目 步骤二 进入微信开发者工具 1、创建 fonts文件夹 > iconfont.wxss 文件,将刚才的代码复制…

【超图】SuperMap iClient3D for WebGL/WebGPU ——地形影像

作者:taco 号外!号外!开新坑了!开新坑了!对于一个代码小白来讲,设置可能是刚接触开发的人(还没接触准备接触)的人来说。对于读代码或是在对产品的使用上会存在许许多多的疑惑。接下来…

Linux开发工具——vim篇

vim开发工具的使用 文章目录 vim开发工具的使用认识vimvim常用三种模式vim正常模式命令集模式切换移动光标删除文字赋值替换撤销上一次操作更改跳到指定的行 vim末行模式命令集列出行号跳到文件中的某一行:保存文件离开vim查找字符: 总结题外话&#xff…