首页 / 经验 / postgresql中使用function()函数的技巧!

postgresql中使用function()函数的技巧!

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

 

如:

 

姓名 白名单地区

 

张三 中国,美国

 

则可使用如下语句:

 

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 <> '';

 

 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;

本文来自网络,不代表糖果站长网立场,转载请注明出处:https://www.1tg.com.cn/html/chuangye/jingyan/2021/0603/8519.html

dawei作者

【声明】:糖果站长网内容转载自互联网,其相关言论仅代表作者个人观点绝非权威,不代表本站立场。如您发现内容存在版权问题,请提交相关链接至邮箱:bqsm@foxmail.com,我们将及时予以处理。
上一篇
下一篇

为您推荐

联系我们

联系我们

0577-28828765

在线咨询: QQ交谈

邮箱: xwei067@foxmail.com

工作时间:周一至周五,9:00-17:30,节假日休息
返回顶部

【免责声明】本站内容转载自互联网,其发布内容言论不代表本站观点,如果其链接、内容的侵犯您的权益,烦请提交相关链接至邮箱xwei067@foxmail.com我们将及时予以处理。

Copygight © 2013-2023 https://www.1tg.com.cn All Rights Reserved.糖果站长网

站长:xwei067#foxmail.com(请把#换成@)