一条SQL语句求每月连续低温时间
2014-04-29 21:32
267 查看
近期为某个项目写存储过程做统计。其中有个是这样的:
求每个月至少连续3个小时低于某个温度值的时间(小时)。
假设有个全年温度表:
思路是这样的:
1、先将低于指定温度的记录都找出来
2、然后在这些记录中找出符合条件的,即那些属于至少连续3小时低于指定温度的记录
至少连续3小时低于指定温度的记录有如下特征:
比如说,有记录 h= 3、4、5、6、7,它们显然满足条件。
m h t
1 3 14
1 4 12
1 5 10
1 6 12
1 7 14
1 9 12
1 10 11
1 13 13
1 15 14
对于 h=3,存在着 h+1,h+2 都低于指定温度
对于 h=4、5、6,存在着 h-1,h+1 都低于指定温度
对于 h=7,存在着 h-1,h-2 都低于指定温度
只要满足这三项条件的任意一项,即可认为该时刻符合条件。因此可得SQL语句:
求每个月至少连续3个小时低于某个温度值的时间(小时)。
假设有个全年温度表:
CREATE TABLE #t(m INT, h INT ,t DECIMAL(18,4));--m:月份 h:小时 t:温度值 --一年有8760小时,因此气候表里面有8760条记录,对应全年每小时的温度值
思路是这样的:
1、先将低于指定温度的记录都找出来
2、然后在这些记录中找出符合条件的,即那些属于至少连续3小时低于指定温度的记录
至少连续3小时低于指定温度的记录有如下特征:
比如说,有记录 h= 3、4、5、6、7,它们显然满足条件。
m h t
1 3 14
1 4 12
1 5 10
1 6 12
1 7 14
1 9 12
1 10 11
1 13 13
1 15 14
对于 h=3,存在着 h+1,h+2 都低于指定温度
对于 h=4、5、6,存在着 h-1,h+1 都低于指定温度
对于 h=7,存在着 h-1,h-2 都低于指定温度
只要满足这三项条件的任意一项,即可认为该时刻符合条件。因此可得SQL语句:
WITH w AS( SELECT [m],[h],[t] FROM #t WHERE [t] < 15 ) SELECT m ,Free = COUNT(*) FROM w WHERE (EXISTS(SELECT 1 FROM w as w1 where m=w.m and h=w.h+1) AND EXISTS(SELECT 1 FROM w as w1 where m=w.m and h=w.h+2)) OR (EXISTS(SELECT 1 FROM w as w1 where m=w.m and h=w.h-1) AND EXISTS(SELECT 1 FROM w as w1 where m=w.m and h=w.h+1)) OR (EXISTS(SELECT 1 FROM w as w1 where m=w.m and h=w.h-1) AND EXISTS(SELECT 1 FROM w as w1 where m=w.m and h=w.h-2)) GROUP BY m;
相关文章推荐
- 一条SQL语句求每月连续低温时间
- 一条SQL语句求每月连续低温时间
- SQL语句:用一条语句找到最早的时间和最近的时间两个记录(在规定时间段内)
- SQL语句:按时间查询最新的一条数据
- 时间段连续判断,实现内容的时间交集计算的sql语句
- 通过sql语句向oracle数据库中插入一条记录(含有主键),系统当前时间插入表中 ,空值插入表中
- Sql语句 表中相同的记录(某个字段)只显示一条,按照时间排序显示最大或最小
- oracle中得到一条SQL语句的执行时间的两种方式
- 怎样一条SQL语句统计该年每月的数据个数
- oracle中得到一条SQL语句的执行时间的两种方式
- 写出一条Sql语句,取出表A中的第31条到第40条记录。表A以自动增长的ID作为主键。(注意:ID可能不是连续的)
- 获取一条SQL语句执行了多少时间
- 获取一条SQL语句执行了多少时间
- 写出一条Sql语句:取出表A中第31到第40记录(SQLServer,以自动增长的ID作为主键,注意:ID可能不是连续的。
- [常见面试题]一条Sql语句:取出表A中第31到第40记录,ID可能不是连续的
- 写出一条Sql语句:取出表A中第31到第40记录(SQLServer,以自动增长的ID作为主键,注意:ID可能不是连续的。
- oracle中如何得到一条SQL语句的执行时间
- 实现内容的时间交集计算的sql语句
- 获取时间差的sql语句
- SQLSERVER查看sql语句的执行时间