存在一个用户白名单表,提供了此用户的用户名和地区信息,判断此用户是否在此白名单表中。
如:
姓名 白名单地区
张三 中国,美国
则可使用如下语句:
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;
文章来源:脚本之家
来源地址:https://www.jb51.net/article/204892.htm
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。
发布者:SEO优化专员,转转请注明出处:https://www.chuangxiangniao.com/p/892834.html