主页 > 知识库 > postgreSql分组统计数据的实现代码

postgreSql分组统计数据的实现代码

热门标签:外呼调研系统 美容工作室地图标注 海丰有多少商家没有地图标注 漯河外呼电话系统 打电话智能电销机器人授权 重庆自动外呼系统定制 合肥公司外呼系统运营商 办公外呼电话系统 地图标注和图片名称的区别

1. 背景

比如气象台的气温监控,每半小时上报一条数据,有很多个地方的气温监控,这样数据表里就会有很多地方的不同时间的气温数据

2. 需求:

每次查询只查最新的气温数据按照不同的温度区间来分组查出,比如:高温有多少地方,正常有多少地方,低温有多少地方

3. 构建数据

3.1 创建表结构:

-- 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 造数据

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. 需求实现

4.1 需求1的SQL语句

利用了postgreSql的一个函数: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

效果如下,查出的都是最新的数据:

4.2 需求2的SQL语句

利用了一个case when then else end 用法来统计数量

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

效果如下,因为没有过滤每个地方的最新数据,查出的是所有数据:

用需求1的结果来查询统计:

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统计,就能查出低温天气,正常天气,高温天气分别合计数量是多少了。

over,enjoy!

到此这篇关于postgreSql分组统计数据的文章就介绍到这了,更多相关postgreSql分组数据内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

您可能感兴趣的文章:
  • postgresql 计算两点距离的2种方法小结
  • postgresql 计算距离的实例(单位直接生成米)
  • postgresql 除法保留小数位的实例
  • PostgreSQL 性能优化之服务器参数配置操作
  • Postgresql的select优化操作(快了200倍)
  • Postgresql 动态统计某一列的某一值出现的次数实例

标签:株洲 乌海 来宾 衡阳 蚌埠 锦州 珠海 晋城

巨人网络通讯声明:本文标题《postgreSql分组统计数据的实现代码》,本文关键词  postgreSql,分组,统计数据,;如发现本文内容存在版权问题,烦请提供相关信息告之我们,我们将及时沟通与处理。本站内容系统采集于网络,涉及言论、版权与本站无关。
  • 相关文章
  • 下面列出与本文章《postgreSql分组统计数据的实现代码》相关的同类信息!
  • 本页收集关于postgreSql分组统计数据的实现代码的相关信息资讯供网民参考!
  • 推荐文章