欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

postgreSql分組統(tǒng)計數(shù)據(jù)的實現(xiàn)代碼

 更新時間:2020年12月29日 15:54:44   作者:Scoful  
這篇文章給大家介紹postgreSql的監(jiān)控記錄表里多條不同時間的數(shù)據(jù),只取最新的數(shù)據(jù),并分組統(tǒng)計,本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友參考下吧

1. 背景

比如氣象臺的氣溫監(jiān)控,每半小時上報一條數(shù)據(jù),有很多個地方的氣溫監(jiān)控,這樣數(shù)據(jù)表里就會有很多地方的不同時間的氣溫數(shù)據(jù)

2. 需求:

每次查詢只查最新的氣溫數(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. 需求實現(xiàn)

4.1 需求1的SQL語句

利用了postgreSql的一個函數(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語句

利用了一個case when then else end 用法來統(tǒng)計數(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

效果如下,因為沒有過濾每個地方的最新數(shù)據(jù),查出的是所有數(shù)據(jù):

在這里插入圖片描述

用需求1的結(jié)果來查詢統(tǒng)計:

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

效果如下:

在這里插入圖片描述

假如再嵌套一個sum統(tǒng)計,就能查出低溫天氣,正常天氣,高溫天氣分別合計數(shù)量是多少了。

over,enjoy!

到此這篇關(guān)于postgreSql分組統(tǒng)計數(shù)據(jù)的文章就介紹到這了,更多相關(guān)postgreSql分組數(shù)據(jù)內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • PostgreSQL15.x安裝的詳細教程

    PostgreSQL15.x安裝的詳細教程

    PostgreSQL 是一個功能強大的開源關(guān)系型數(shù)據(jù)庫系統(tǒng),基于 C 語言實現(xiàn),采用 PostgreSQL 許可證,這是一種自由軟件許可證,允許用戶自由使用、修改和分發(fā)源代碼,所以本文將給大家介紹PostgreSQL15.x安裝的詳細教程,需要的朋友可以參考下
    2024-09-09
  • PostgreSQL實戰(zhàn)之啟動恢復讀取checkpoint記錄失敗的條件詳解

    PostgreSQL實戰(zhàn)之啟動恢復讀取checkpoint記錄失敗的條件詳解

    這篇文章主要給大家介紹了關(guān)于PostgreSQL實戰(zhàn)之啟動恢復讀取checkpoint記錄失敗的條件的相關(guān)資料,文中通過示例代碼介紹的非常詳細,需要的朋友可以參考借鑒,下面隨著小編來一起學習學習吧
    2018-08-08
  • postgresql查詢每個月的最后一天日期并對未查到的日期結(jié)果補0(操作示例)

    postgresql查詢每個月的最后一天日期并對未查到的日期結(jié)果補0(操作示例)

    這篇文章主要介紹了postgresql查詢每個月的最后一天日期,并對未查到的日期結(jié)果補0,pgsql需要使用函數(shù)使用date_trunc()函數(shù)找到指定月第一天,然后對該日期先加一個月在減一個月就能得到你傳給的日期的最后一天日期,感興趣的朋友跟隨小編一起看看吧
    2023-10-10
  • PostgreSQL自定義函數(shù)并且調(diào)用方式

    PostgreSQL自定義函數(shù)并且調(diào)用方式

    這篇文章主要介紹了PostgreSQL如何自定義函數(shù)并且調(diào)用,本文通過示例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2023-06-06
  • 對PostgreSQL中的慢查詢進行分析和優(yōu)化的操作指南

    對PostgreSQL中的慢查詢進行分析和優(yōu)化的操作指南

    在數(shù)據(jù)庫的世界里,慢查詢就像是路上的絆腳石,讓數(shù)據(jù)處理的道路變得崎嶇不平,想象一下,你正在高速公路上飛馳,突然遇到一堆減速帶,那感覺肯定糟透了,本文介紹了怎樣對?PostgreSQL?中的慢查詢進行分析和優(yōu)化,需要的朋友可以參考下
    2024-07-07
  • 詳解PostgreSQL啟動停止命令(重啟)

    詳解PostgreSQL啟動停止命令(重啟)

    這篇文章主要介紹了PostgreSQL啟動停止命令(重啟)的相關(guān)資料,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友參考下吧
    2023-11-11
  • postgreSQL如何設置數(shù)據(jù)庫執(zhí)行超時時間

    postgreSQL如何設置數(shù)據(jù)庫執(zhí)行超時時間

    本文我們將深入探討PostgreSQL數(shù)據(jù)庫中的一個關(guān)鍵設置SET?statement_timeout,這個設置對于管理數(shù)據(jù)庫性能和優(yōu)化查詢執(zhí)行時間非常重要,讓我們一起來了解它的工作原理以及如何有效地使用它
    2024-01-01
  • 使用PostGIS完成兩點間的河流軌跡及流經(jīng)長度的計算(推薦)

    使用PostGIS完成兩點間的河流軌跡及流經(jīng)長度的計算(推薦)

    這篇文章主要介紹了使用PostGIS完成兩點間的河流軌跡及流經(jīng)長度的計算,使用POSTGIS及其擴展pgrouting計算給定兩點間的河流流經(jīng)區(qū)域和河流長度,需要的朋友可以參考下
    2022-01-01
  • postgresql兼容MySQL on update current_timestamp問題

    postgresql兼容MySQL on update current_timestamp

    這篇文章主要介紹了postgresql兼容MySQL on update current_timestamp問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-03-03
  • Postgresql源碼分析returns?setof函數(shù)oracle管道pipelined

    Postgresql源碼分析returns?setof函數(shù)oracle管道pipelined

    這篇文章主要為大家介紹了Postgresql源碼分析returns?setof函數(shù)oracle管道pipelined,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-01-01

最新評論