时间:2021-05-24
存在一个用户白名单表,提供了此用户的用户名和地区信息,判断此用户是否在此白名单表中。
如:
姓名 白名单地区
张三 中国,美国
则可使用如下语句:
SELECT ID, user, area_listFROM t_white_userWHERE user = #{ user, jdbcType = VARCHAR }AND ( COALESCE (area_list, '') LIKE CONCAT ( '%' ,#{ country, jdbcType = VARCHAR }, '%' ) OR area_list IS NULL)LIMIT 11、coalesce函数说明:返回其参数中第一个非空表达式,这里使用即 area_list
2、白名单地区为多个国家以逗号分隔,则使用like concat的方式,能查询出某个国家是否被包含其中。
补充:PostgreSQL - null和''的区别与判断以及COALESCE函数
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函数是返回参数中的第一个非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;以上为个人经验,希望能给大家一个参考,也希望大家多多支持。如有错误或未考虑完全的地方,望不吝赐教。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
oracle的NVL(col,0)是判断如果col字段为空的时候赋值0,同样的postgresql中的函数就是coalesce,用法是一样的SELECTcoal
SQLServerCOALESCE函数详解很多人知道ISNULL函数,但是很少人知道Coalesce函数,人们会无意中使用到Coalesce函数,并且发现它比I
coalesce函数可以接受多个参数,将会返回这些参数中第一个非NULL的值,若提供的参数全部为NULL,则返回NULLifnull函数和coalesce功能一
前言最近无意间发现mysql的coalesce,又正好有时间,就把mysql中coalesce()的使用技巧总结下分享给大家,下面来一起看看详细的介绍:coal
PostgreSQL函数也称为PostgreSQL存储过程。PostgreSQL函数或存储过程是存储在数据库服务器上并可以使用SQL界面调用的一组SQL和过程语