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; (编辑:宣城站长网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! | 


