PostgreSQL(MySQL)插入操作传入值为空则设置默认值

1、mysql写法

IFNULL(p1,p2),如果p1有值就是p1,如果p1是空,则值为p2

<insert id="insertForeach" parameterType="java.util.List" >
    insert into user_message
        ( skip_id )
    values
        <foreach collection="list" item="userMessage" index="index" separator=",">
            ( ifnull(#{userMessage.skipId},"0") )
        </foreach>
</insert>

2、postgresql写法

COALESCE函数是返回参数中的第一个非null的值,它要求参数中至少有一个是非null的,如果参数都是null会报错

select COALESCE(null,null); //报错
select COALESCE(null,null,now(),''); //结果会得到当前的时间
select COALESCE(null,null,'',now()); //结果会得到''

//可以和其他函数配合来实现一些复杂点的功能:查询学生姓名,如果学生名字为null或''则显示“姓名为空”
select case when coalesce(name,'') = '' then '姓名为空' else name end from student;

问题到此解决。

地表最强菜鸡 CSDN认证博客专家 架构师 项目经理
从事 Java开发、嵌入式C、前端开发、基础设施运维、小程序开发等,有丰富的物联网实战经验,帮助团队需求梳理、项目研发、云原生自动化运维、技术难点攻关落地等。
已标记关键词 清除标记
相关推荐
©️2020 CSDN 皮肤主题: 博客之星2020 设计师:CY__ 返回首页
实付 39.90元
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、C币套餐、付费专栏及课程。

余额充值