PostGreSQL:货币类型

货币类型:money

money类型存储固定小数精度的货币数字,小数的精度由数据库的lc_monetary设置决定。windows系统下,该配置项位于/data/postgresql.conf文件中,默认配置如下,

lc_monetary = 'Chinese (Simplified)_China.936' # locale for monetary formatting

货币类型输入输出格式

可接受的输入格式很多,包括整数和浮点数文字,以及常用的货币格式,如'$1,000.00'。 输出通常是最后一种形式,但和区域相关。也就是说:++money这种数据类型的输出格式是和区域相关的++。例如:上述配置对应于中国区域,那么货币的输出格式就为:

SELECT id,name,money FROM "tb_account"

ORDER BY id

查询结果如下,

因此将money数据装入到一个具有不同lc_monetary设置的数据库是不起作用的。为了避免这种问题,在恢复一个转储到一个新数据库中之前,应确保新数据库的lc_monetary设置和被转储数据库的相同或者具有等效值。

货币类型与其它数据类型相互转换

在实际开发中,我们经常接触到的金额数值一般为小数类型,但是,PostGreSQL货币类型由于输出格式带有前缀$或者¥,显然是无法直接映射到Double/Float/Int等数值类型的,尤其是在使用MyBatis框架时。

为了解决这类问题,PostGreSQL提供了类型转换的实现方式。

其它类型转货币类型

数据类型numericintbigint的值可以被造型成money。从数据类型realdouble precision的转换可以通过先造型成numeric来实现,例如:

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

对应于MyBatis框架,使用方式如下,

XML 复制代码
  <update id="update" parameterType="com.example.demo.demos.pojo.Account">
        UPDATE tb_account
        <trim prefix="SET" suffixOverrides=",">
            <if test="account.name != null and account.name != ''">
                name = #{account.name},
            </if>
            <if test="account.money != null">
                money = #{account.money}::float8::numeric::money,
            </if>
        </trim>
        WHERE id = #{account.id}
   </update>

货币类型转其它类型

一个money值可以在不损失精度的情况下被造型成numeric。转换到其他类型可能会丢失精度,并且必须采用两个阶段完成:

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

对应于MyBatis框架,使用方式如下,

XML 复制代码
<select id="selectList" resultType="com.example.demo.demos.pojo.Account">
        SELECT id,name,money::money::numeric::float8 as money
        FROM tb_account
</select>

tb_account表对应的pojo实体类定义如下,

java 复制代码
package com.example.demo.demos.pojo;


import java.io.Serializable;

public class Account implements Serializable {
    private static final long serialVersionUID = 3327456920493219212L;

    /**
     * id-主键
     */
    private Integer id;

    /**
     * name-账户名
     */
    private String name;

    /**
     * money-金额
     */
    private Double money;

    //setter
    public void setId(Integer id) {
        this.id = id;
    }

    public void setName(String name) {
        this.name = name;
    }

    public void setMoney(Double money) {
        this.money = money;
    }


    //getter
    public Integer getId() {
        return id;
    }

    public String getName() {
        return name;
    }

    public Double getMoney() {
        return money;
    }

    //constructor
    public Account() {
    }

    public Account(Integer id, String name, Double money) {
        this.id = id;
        this.name = name;
        this.money = money;
    }

    //methods
    @Override
    public String toString() {
        return "Account{" +
                "id=" + id +
                ", name='" + name + '\'' +
                ", money=" + money +
                '}';
    }
}
相关推荐
程序员卷卷狗2 分钟前
Redis事务与MySQL事务有什么区别?一文分清
数据库·redis·mysql
玩大数据的龙威29 分钟前
农经权二轮延包—数据(新老农经权)比对软件更新
数据库·arcgis
保持低旋律节奏40 分钟前
网络系统管理——期末复习
数据库
程序员佳佳1 小时前
2025年大模型终极横评:GPT-5.2、Banana Pro与DeepSeek V3.2实战硬核比拼(附统一接入方案)
服务器·数据库·人工智能·python·gpt·api
roo_12 小时前
github 获取构造图数据库的LNB数据集和使用说明
数据库
罗汉松驻扎的工作基地3 小时前
sql server 2014 下载和安装
数据库
l1t4 小时前
用docker安装oracle 19c
运维·数据库·docker·oracle·容器
Java&Develop4 小时前
DataEase图表页面传参至数据库查询方法 和页面筛选方法 sql传参
数据库·sql
+VX:Fegn08954 小时前
计算机毕业设计|基于springboot + vue作业管理系统(源码+数据库+文档)
数据库·vue.js·spring boot·后端·课程设计
@zulnger4 小时前
Python 连接 MySQL 数据库_pymysql
数据库·python·mysql