当前位置:   article > 正文

postgresql没有nvl的解决办法,postgresql查询所有的表_pg nvl

pg nvl

postgresql没有nvl的解决办法

oracle 的NVL(col,0)是判断如果col字段为空的时候赋值0。
postgresql里也有类似的方法COALESCE,
COALESCE函数是返回参数中的第一个非null的值,它要求参数中至少有一个是非null的,如果参数都是null会报错,如下

SELECT coalesce(collect_result,0) as collect_result  FROM collect
  • 1
select COALESCE(null,null); //报错
select COALESCE(null,null,now()::varchar,''); //结果会得到当前的时间
select COALESCE(null,null,'',now()::varchar); //结果会得到''
//可以和其他函数配合来实现一些复杂点的功能:查询学生姓名,如果学生名字为null或''则显示“姓名为空”
select case when coalesce(name,'') = '' then '姓名为空' else name end from student;
  • 1
  • 2
  • 3
  • 4
  • 5

postgresql查询所有的表

select * from pg_tables where schemaname = '模式名' order by tablename asc;
  • 1
声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/知新_RL/article/detail/974741
推荐阅读
相关标签
  

闽ICP备14008679号