postgresql 中的COALESCE()函數(shù)使用小技巧
場景:
存在一個用戶白名單表,提供了此用戶的用戶名和地區(qū)信息,判斷此用戶是否在此白名單表中。
如:
姓名 白名單地區(qū)
張三 中國,美國
則可使用如下語句:
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函數(shù)說明:返回其參數(shù)中第一個非空表達式,這里使用即 area_list
2、白名單地區(qū)為多個國家以逗號分隔,則使用like concat的方式,能查詢出某個國家是否被包含其中。
補充:PostgreSQL - null和''的區(qū)別與判斷以及COALESCE函數(shù)
null和''的區(qū)別與判斷
null是一種類型,''是空字符串,打個比方,''是你參加了考試且得了零分,而null則是你壓根就沒有參加考試。
如果要在sql中對兩者進行判斷,是有區(qū)別的:
//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函數(shù)
COALESCE函數(shù)是返回參數(shù)中的第一個非null的值,它要求參數(shù)中至少有一個是非null的,如果參數(shù)都是null會報錯。
select COALESCE(null,null); //報錯 select COALESCE(null,null,now()::varchar,''); //結果會得到當前的時間 select COALESCE(null,null,'',now()::varchar); //結果會得到'' //可以和其他函數(shù)配合來實現(xiàn)一些復雜點的功能:查詢學生姓名,如果學生名字為null或''則顯示“姓名為空” select case when coalesce(name,'') = '' then '姓名為空' else name end from student;
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。如有錯誤或未考慮完全的地方,望不吝賜教。
- MySQL語句之條件語句IFNULL和COALESCE的區(qū)別說明
- postgresql coalesce函數(shù)數(shù)據(jù)轉換方式
- PostgreSQL COALESCE使用方法代碼解析
- MySql COALESCE函數(shù)使用方法代碼案例
- mysql中null(IFNULL,COALESCE和NULLIF)相關知識點總結
- mysql中coalesce()的使用技巧小結
- mysql中替代null的IFNULL()與COALESCE()函數(shù)詳解
- SQL Server COALESCE函數(shù)詳解及實例
- 淺析SQL Server的分頁方式 ISNULL與COALESCE性能比較
- sql coalesce函數(shù)的具體使用
相關文章
PostgreSQL向數(shù)據(jù)庫表中添加行數(shù)據(jù)的操作
這篇文章主要介紹了PostgreSQL向數(shù)據(jù)庫表中添加行數(shù)據(jù)的操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2021-02-02
postgresql數(shù)據(jù)合并,多條數(shù)據(jù)合并成1條的操作
這篇文章主要介紹了postgresql數(shù)據(jù)合并,多條數(shù)據(jù)合并成1條的操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2021-02-02
PostgreSQL 如何查找需要收集的vacuum 表信息
這篇文章主要介紹了PostgreSQL 如何查找需要收集的vacuum 表信息,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2021-02-02
Windows?環(huán)境搭建?PostgreSQL?邏輯復制高可用架構數(shù)據(jù)庫服務
本文主要介紹Windows下搭建PostgreSQL的主從邏輯復制,關于PostgreSQl的相關運維文章,網(wǎng)絡上大多都是?Linux?環(huán)境下的操作,鮮有在?Windows?環(huán)境下配置的教程,所以本文采用?Windows?環(huán)境作為演示系統(tǒng)來進行?PostgreSQL?高可用數(shù)據(jù)庫服務的搭建,感興趣的朋友一起看看吧2023-05-05
CentOS 7下安裝PostgreSQL 9.6的教程分享
PostgreSQL在我心目中的地位要遠遠高于MySQL,雖然流行對比MySQL低很對,但是功能性一致走在MySQL的前面。下面這篇文章主要介紹了CentOS 7下安裝PostgreSQL數(shù)據(jù)庫的方法,需要的朋友可以參考借鑒,一起來看看吧。2017-02-02
postgresql 實現(xiàn)獲取所有表名,字段名,字段類型,注釋
這篇文章主要介紹了postgresql 實現(xiàn)獲取所有表名,字段名,字段類型,注釋操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2021-01-01

