您好,登錄后才能下訂單哦!
COALESCE()函數(shù)怎么在postgresql 中使用?很多新手對此不是很清楚,為了幫助大家解決這個難題,下面小編將為大家詳細(xì)講解,有這方面需求的人可以來學(xué)習(xí)下,希望你能有所收獲。
存在一個用戶白名單表,提供了此用戶的用戶名和地區(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是一種類型,''是空字符串,打個比方,''是你參加了考試且得了零分,而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ù)是返回參數(shù)中的第一個非null的值,它要求參數(shù)中至少有一個是非null的,如果參數(shù)都是null會報錯。
select COALESCE(null,null); //報錯 select COALESCE(null,null,now()::varchar,''); //結(jié)果會得到當(dāng)前的時間 select COALESCE(null,null,'',now()::varchar); //結(jié)果會得到'' //可以和其他函數(shù)配合來實現(xiàn)一些復(fù)雜點的功能:查詢學(xué)生姓名,如果學(xué)生名字為null或''則顯示“姓名為空” select case when coalesce(name,'') = '' then '姓名為空' else name end from student;
看完上述內(nèi)容是否對您有幫助呢?如果還想對相關(guān)知識有進一步的了解或閱讀更多相關(guān)文章,請關(guān)注億速云行業(yè)資訊頻道,感謝您對億速云的支持。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。