主页 > 知识库 > postgresql 中的COALESCE()函数使用小技巧

postgresql 中的COALESCE()函数使用小技巧

热门标签:移动外呼系统模拟题 广州电销机器人公司招聘 济南外呼网络电话线路 地图标注要花多少钱 电话机器人怎么换人工座席 400电话申请客服 电销机器人能补救房产中介吗 天津开发区地图标注app 江苏400电话办理官方

场景:

存在一个用户白名单表,提供了此用户的用户名和地区信息,判断此用户是否在此白名单表中。

如:

姓名 白名单地区

张三 中国,美国

则可使用如下语句:

SELECT
  ID,
  user,
  area_list
FROM
  t_white_user
WHERE
  user = #{ user,
  jdbcType = VARCHAR }
AND (
  COALESCE (area_list, '') LIKE CONCAT (
    '%' ,#{ country,
    jdbcType = VARCHAR }, '%'
  )
  OR area_list IS NULL
)
LIMIT 1

技巧点分析:

1、coalesce函数说明:返回其参数中第一个非空表达式,这里使用即 area_list

2、白名单地区为多个国家以逗号分隔,则使用like concat的方式,能查询出某个国家是否被包含其中。

补充:PostgreSQL - null和''的区别与判断以及COALESCE函数

null和''的区别与判断

null是一种类型,''是空字符串,打个比方,''是你参加了考试且得了零分,而null则是你压根就没有参加考试。

如果要在sql中对两者进行判断,是有区别的:

//null只能和is或is not搭配,不能使用=、!=或者>
select * from student where name is null;
select * from student where name is not null;
//''的判断可以使用=、!=或者>
select * from student where name = '';
select * from student where name != '';
select * from student where name > '';

使用COALESCE函数

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

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;

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。如有错误或未考虑完全的地方,望不吝赐教。

您可能感兴趣的文章:
  • postgresql SQL语句变量的使用说明
  • PostgreSQL 正则表达式替换-使用变量方式
  • postgresql 导入数据库表并重设自增属性的操作
  • postgresql coalesce函数数据转换方式
  • postgresql 实现修改jsonb字段中的某一个值
  • postgresql 存储函数调用变量的3种方法小结

标签:杭州 昭通 辛集 海西 温州 宝鸡 榆林 濮阳

巨人网络通讯声明:本文标题《postgresql 中的COALESCE()函数使用小技巧》,本文关键词  postgresql,中的,COALESCE,函数,;如发现本文内容存在版权问题,烦请提供相关信息告之我们,我们将及时沟通与处理。本站内容系统采集于网络,涉及言论、版权与本站无关。
  • 相关文章
  • 下面列出与本文章《postgresql 中的COALESCE()函数使用小技巧》相关的同类信息!
  • 本页收集关于postgresql 中的COALESCE()函数使用小技巧的相关信息资讯供网民参考!
  • 推荐文章