postgreSql分組統(tǒng)計(jì)數(shù)據(jù)的實(shí)現(xiàn)代碼
1. 背景
比如氣象臺(tái)的氣溫監(jiān)控,每半小時(shí)上報(bào)一條數(shù)據(jù),有很多個(gè)地方的氣溫監(jiān)控,這樣數(shù)據(jù)表里就會(huì)有很多地方的不同時(shí)間的氣溫?cái)?shù)據(jù)
2. 需求:
每次查詢只查最新的氣溫?cái)?shù)據(jù)按照不同的溫度區(qū)間來分組查出,比如:高溫有多少地方,正常有多少地方,低溫有多少地方
3. 構(gòu)建數(shù)據(jù)
3.1 創(chuàng)建表結(jié)構(gòu):
-- DROP TABLE public.t_temperature CREATE TABLE public.t_temperature ( id int4 NOT NULL GENERATED ALWAYS AS IDENTITY, place_name varchar NOT NULL, value float8 NOT NULL, up_time timestamp NOT NULL, CONSTRAINT t_temperature_pk PRIMARY KEY (id) ); -- Permissions ALTER TABLE public.t_temperature OWNER TO postgres; GRANT ALL ON TABLE public.t_temperature TO postgres;
3.2 造數(shù)據(jù)
INSERT INTO public.t_temperature (place_name,value,up_time) VALUES ('廣州',35,'2020-07-12 15:00:00.000') ,('廣州',35.9,'2020-07-12 15:30:00.000') ,('深圳',30,'2020-07-12 15:30:00.000') ,('深圳',31,'2020-07-12 16:30:00.000') ,('三亞',23,'2020-07-12 16:30:00.000') ,('三亞',21,'2020-07-12 17:30:00.000') ,('北極',-1,'2020-07-12 17:30:00.000') ,('北極',-10,'2020-07-12 19:30:00.000') ;
4. 需求實(shí)現(xiàn)
4.1 需求1的SQL語句
利用了postgreSql的一個(gè)函數(shù):ROW_NUMBER() OVER( [ PRITITION BY col1] ORDER BY col2[ DESC ] )
select * from ( select tt.place_name, tt.value, tt.up_time, row_number() over ( partition by tt.place_name order by tt.up_time desc) as row_num from t_temperature tt) aaa where aaa.row_num = 1
效果如下,查出的都是最新的數(shù)據(jù):
4.2 需求2的SQL語句
利用了一個(gè)case when then else end 用法來統(tǒng)計(jì)數(shù)量
select dd.place_name, sum(case when dd.value <= 0 then 1 else 0 end) as 低溫天氣, sum(case when dd.value > 0 and dd.value < 25 then 1 else 0 end) as 正常天氣, sum(case when dd.value >= 25 then 1 else 0 end) as 高溫天氣 from t_temperature dd group by dd.place_name
效果如下,因?yàn)闆]有過濾每個(gè)地方的最新數(shù)據(jù),查出的是所有數(shù)據(jù):
用需求1的結(jié)果來查詢統(tǒng)計(jì):
select dd.place_name, sum(case when dd.value <= 0 then 1 else 0 end) as 低溫天氣, sum(case when dd.value > 0 and dd.value < 25 then 1 else 0 end) as 正常天氣, sum(case when dd.value >= 25 then 1 else 0 end) as 高溫天氣 from ( select * from ( select tt.place_name, tt.value, tt.up_time, row_number() over ( partition by tt.place_name order by tt.up_time desc) as row_num from t_temperature tt) aaa where aaa.row_num = 1) dd group by dd.place_name
效果如下:
假如再嵌套一個(gè)sum統(tǒng)計(jì),就能查出低溫天氣,正常天氣,高溫天氣分別合計(jì)數(shù)量是多少了。
over,enjoy!
到此這篇關(guān)于postgreSql分組統(tǒng)計(jì)數(shù)據(jù)的文章就介紹到這了,更多相關(guān)postgreSql分組數(shù)據(jù)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
PostgreSQL實(shí)戰(zhàn)之啟動(dòng)恢復(fù)讀取checkpoint記錄失敗的條件詳解
這篇文章主要給大家介紹了關(guān)于PostgreSQL實(shí)戰(zhàn)之啟動(dòng)恢復(fù)讀取checkpoint記錄失敗的條件的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),需要的朋友可以參考借鑒,下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2018-08-08postgresql查詢每個(gè)月的最后一天日期并對(duì)未查到的日期結(jié)果補(bǔ)0(操作示例)
這篇文章主要介紹了postgresql查詢每個(gè)月的最后一天日期,并對(duì)未查到的日期結(jié)果補(bǔ)0,pgsql需要使用函數(shù)使用date_trunc()函數(shù)找到指定月第一天,然后對(duì)該日期先加一個(gè)月在減一個(gè)月就能得到你傳給的日期的最后一天日期,感興趣的朋友跟隨小編一起看看吧2023-10-10PostgreSQL自定義函數(shù)并且調(diào)用方式
這篇文章主要介紹了PostgreSQL如何自定義函數(shù)并且調(diào)用,本文通過示例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2023-06-06對(duì)PostgreSQL中的慢查詢進(jìn)行分析和優(yōu)化的操作指南
在數(shù)據(jù)庫的世界里,慢查詢就像是路上的絆腳石,讓數(shù)據(jù)處理的道路變得崎嶇不平,想象一下,你正在高速公路上飛馳,突然遇到一堆減速帶,那感覺肯定糟透了,本文介紹了怎樣對(duì)?PostgreSQL?中的慢查詢進(jìn)行分析和優(yōu)化,需要的朋友可以參考下2024-07-07postgreSQL如何設(shè)置數(shù)據(jù)庫執(zhí)行超時(shí)時(shí)間
本文我們將深入探討PostgreSQL數(shù)據(jù)庫中的一個(gè)關(guān)鍵設(shè)置SET?statement_timeout,這個(gè)設(shè)置對(duì)于管理數(shù)據(jù)庫性能和優(yōu)化查詢執(zhí)行時(shí)間非常重要,讓我們一起來了解它的工作原理以及如何有效地使用它2024-01-01使用PostGIS完成兩點(diǎn)間的河流軌跡及流經(jīng)長度的計(jì)算(推薦)
這篇文章主要介紹了使用PostGIS完成兩點(diǎn)間的河流軌跡及流經(jīng)長度的計(jì)算,使用POSTGIS及其擴(kuò)展pgrouting計(jì)算給定兩點(diǎn)間的河流流經(jīng)區(qū)域和河流長度,需要的朋友可以參考下2022-01-01postgresql兼容MySQL on update current_timestamp
這篇文章主要介紹了postgresql兼容MySQL on update current_timestamp問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-03-03Postgresql源碼分析returns?setof函數(shù)oracle管道pipelined
這篇文章主要為大家介紹了Postgresql源碼分析returns?setof函數(shù)oracle管道pipelined,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-01-01