postgreSQL中的case用法說明
工具:postgreSQL
Navicat Premium
又一次在看代碼的時候,發(fā)現(xiàn)了不懂的東西!
這次就是case when then
SQL CASE表達式是一種通用的條件表達式,類似于其它語言中的if/else語句。
CASE WHEN condition THEN result [WHEN ...] [ELSE result] END
解釋:
condition是一個返回boolean的表達式。
如果為真,那么CASE表達式的結(jié)果就是符合條件的result。
如果結(jié)果為假,那么以相同方式 搜尋隨后的WHEN子句。
如果沒有WHEN condition為真,那么case表達式的結(jié)果就是在ELSE子句里的值。
如果省略了ELSE子句而且沒有匹配的條件,結(jié)果為NULL。
select * from city
我們的測試數(shù)據(jù):
select SUM(city_id),case name when '北京' then '古都' when '西安' THEN '古都' when '上海' THEN '魔都' when 'NewYork' then '紐約' else '其他城市' END from city GROUP BY case name when '北京' then '古都' when '西安' THEN '古都' when '上海' THEN '魔都' when 'NewYork' then '紐約' else '其他城市' END
結(jié)果如下:
select sum(city_id),CASE when city_id < 3 then '小于3' when city_id > 8 then '大于8' else '大于3小于8' END FROM city group by CASE when city_id < 3 then '小于3' when city_id > 8 then '大于8' else '大于3小于8' END order by CASE when city_id < 3 then '小于3' when city_id > 8 then '大于8' else '大于3小于8' END DESC
結(jié)果如下:
根據(jù)上面兩個例子可以明確的看出:
第一:為了在 GROUP BY 塊中使用 CASE,查詢語句需要在 GROUP BY 塊中重復(fù) SELECT 塊中的 CASE 塊
第二:為了在ORDER BY塊中使用CASE,查詢語句需要在ORDER BY塊中重復(fù)SELECT 塊中的 CASE 塊
第三:如果要比較的數(shù)據(jù)為數(shù)字,則在case 后不能寫 字段名,如果要比較的數(shù)據(jù)為字符,則要在case后寫上字段名
補充:Postgresql中(case、when)的用法
1.case when
( case when substr(starttime::varchar,0,5)='2020' then '2020年' when substr(starttime::varchar,0,5)='2019' then '2019年' when substr(starttime::varchar,0,5)='2018' then '2018年' when substr(starttime::varchar,0,5)='2017' then '2017年' when substr(starttime::varchar,0,5)='2016' then '2016年' when substr(starttime::varchar,0,5)='2015' then '2015年' when substr(starttime::varchar,0,5)='2014' then '2014年' when substr(starttime::varchar,0,5)='2013' then '2013年' when substr(starttime::varchar,0,5)='2012' then '2012年' when substr(starttime::varchar,0,5)='2011' then '2011年' when substr(starttime::varchar,0,5)='2010' then '2010年' when starttime is null then '其他年份' end ) AS year
2.mybatis中判斷某個傳參是否為空
<if test="geojsonString !=null and geojsonString !=''"> WHERE st_intersects(geom,st_geomfromgeojson(#{geojsonString})) </if>
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。如有錯誤或未考慮完全的地方,望不吝賜教。
相關(guān)文章
PostgreSQL 數(shù)據(jù)庫跨版本升級常用方案解析
這篇文章主要介紹了PostgreSQL 數(shù)據(jù)庫跨版本升級常用方案解析,本文給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2021-03-03sqoop讀取postgresql數(shù)據(jù)庫表格導(dǎo)入到hdfs中的實現(xiàn)
這篇文章主要介紹了sqoop讀取postgresql數(shù)據(jù)庫表格導(dǎo)入到hdfs中的實現(xiàn),具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-12-12postgresql如何找到表中重復(fù)數(shù)據(jù)的行并刪除
這篇文章主要介紹了postgresql如何找到表中重復(fù)數(shù)據(jù)的行并刪除問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2023-05-05PostgreSQL關(guān)閉數(shù)據(jù)庫服務(wù)的三種模式
PostgreSQL 提供了三種關(guān)閉數(shù)據(jù)庫服務(wù)的不同方式,它們最終都是發(fā)送一個關(guān)閉信號到 postgres 主服務(wù)進程,本文將給大家詳細的介紹一下這三種模式,需要的朋友可以參考下2024-07-07PostgreSQL基礎(chǔ)知識之SQL操作符實踐指南
這篇文章主要給大家介紹了關(guān)于PostgreSQL基礎(chǔ)知識之SQL操作符實踐的相關(guān)資料,文中通過示例代碼介紹的非常詳細,對大家學(xué)習(xí)或者使用PostgreSQL具有一定的參考學(xué)習(xí)價值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧2020-05-05Postgresql數(shù)據(jù)庫角色創(chuàng)建登錄詳解
這篇文章主要為大家介紹了Postgresql數(shù)據(jù)庫角色創(chuàng)建登錄詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2023-02-02postgresql 數(shù)據(jù)庫 與TimescaleDB 時序庫 join 在一起
這篇文章主要介紹了postgresql 數(shù)據(jù)庫 與TimescaleDB 時序庫 join 在一起,需要的朋友可以參考下2020-12-12postgresql 實現(xiàn)啟動、狀態(tài)查看、關(guān)閉
這篇文章主要介紹了postgresql 實現(xiàn)啟動、狀態(tài)查看、關(guān)閉的操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2021-01-01