求2个查询,谢谢~

Walkline 2018-12-26 05:46:11
表里字段包括温度和时间戳,我需要查询现在时间8小时以内的记录,8小时里每个小时取第一条和第六条记录,一共取16条记录,但是当前时间这个小时内可能没有这么多记录,那么只取第一条就行

第二个查询是这样,取8小时内温度有变化的记录,比如第一条记录23度,第二条记录23度,第三条记录23.1度,第四条记录24度,那么返回数据集应该是第一条、第三条、第四条记录,因为第一条作为起始点需要保留

求大佬们解决一下,谢谢~~
...全文
254 4 打赏 收藏 转发到动态 举报
写回复
用AI写文章
4 条回复
切换为时间正序
请发表友善的回复…
发表回复
Walkline 2018-12-30
  • 打赏
  • 举报
回复
引用 2 楼 吉普赛的歌 的回复:
drop table if exists t;
create table t(
id int not null AUTO_INCREMENT primary key,
wd DECIMAL(10,2),
addTime datetime
);
INSERT t (wd,addTime) values(10,'2018-12-27 03:00');
INSERT t (wd,addTime) values(10,'2018-12-27 03:01');
INSERT t (wd,addTime) values(11,'2018-12-27 03:10');
INSERT t (wd,addTime) values(12,'2018-12-27 03:12');
INSERT t (wd,addTime) values(13,'2018-12-27 03:13');
INSERT t (wd,addTime) values(14,'2018-12-27 03:20');
INSERT t (wd,addTime) values(10,'2018-12-27 04:00');
INSERT t (wd,addTime) values(10,'2018-12-27 05:01');
INSERT t (wd,addTime) values(11,'2018-12-27 06:10');
INSERT t (wd,addTime) values(12,'2018-12-27 07:12');
INSERT t (wd,addTime) values(13,'2018-12-27 08:13');
INSERT t (wd,addTime) values(23,'2018-12-27 09:20');
# 以上为测试数据

/*
1. 查询现在时间8小时以内的记录,8小时里每个小时取第一条和第六条记录,一共取16条记录,但是当前时间这个小时内可能没有这么多记录,那么只取第一条就行
*/
select * from (
select
(
SELECT COUNT(*) FROM t t2 WHERE
1=1
AND DATE_FORMAT(t1.addTime,'%Y-%m-%d %H')= DATE_FORMAT(t2.addTime,'%Y-%m-%d %H')
AND t1.id >= t2.id
) as rid
,id
,wd
,addTime
from t as t1 where t1.addTime>DATE_ADD(t1.addTime,INTERVAL -8 hour)
) as tt
where rid in (1,6);
/*
+-----+----+-------+---------------------+
| rid | id | wd | addTime |
+-----+----+-------+---------------------+
| 1 | 1 | 10.00 | 2018-12-27 03:00:00 |
| 6 | 6 | 14.00 | 2018-12-27 03:20:00 |
| 1 | 7 | 10.00 | 2018-12-27 04:00:00 |
| 1 | 8 | 10.00 | 2018-12-27 05:01:00 |
| 1 | 9 | 11.00 | 2018-12-27 06:10:00 |
| 1 | 10 | 12.00 | 2018-12-27 07:12:00 |
| 1 | 11 | 13.00 | 2018-12-27 08:13:00 |
| 1 | 12 | 23.00 | 2018-12-27 09:20:00 |
+-----+----+-------+---------------------+
*/

/*
2. 取8小时内温度有变化的记录,比如第一条记录23度,第二条记录23度,第三条记录23.1度,第四条记录24度,那么返回数据集应该是第一条、第三条、第四条记录,因为第一条作为起始点需要保留
*/
drop TEMPORARY TABLE if exists tmp;
drop TEMPORARY TABLE if exists tmp2;
CREATE TEMPORARY TABLE tmp(
rid int,
id int,
wd DECIMAL(10,2),
addTime datetime,
timeSeg int
);
CREATE TEMPORARY TABLE tmp2(
rid int,
id int,
wd DECIMAL(10,2),
addTime datetime,
timeSeg int
);

insert into tmp
select * from (
select
(
SELECT COUNT(*) FROM t t2 WHERE
1=1
AND DATE_FORMAT(t1.addTime,'%Y-%m-%d %H')= DATE_FORMAT(t2.addTime,'%Y-%m-%d %H')
AND t1.id >= t2.id
) as rid
,id
,wd
,addTime
,DATE_FORMAT(t1.addTime,'%Y%m%d%H') as timeSeg
from t as t1 where t1.addTime>DATE_ADD(t1.addTime,INTERVAL -8 hour)
) as tt
;
insert into tmp2
select * from tmp;

select
id
,wd
,addTime
from (
select a.*,case when a.rid=1 or (b.wd is not null and a.wd!=b.wd) then 1 else 0 end as r from tmp as a
left join tmp2 as b on a.timeSeg=b.timeSeg and a.rid=b.rid+1
) as tt
where tt.r=1
order by tt.timeSeg,tt.rid
;
/*
+----+-------+---------------------+
| id | wd | addTime |
+----+-------+---------------------+
| 1 | 10.00 | 2018-12-27 03:00:00 |
| 3 | 11.00 | 2018-12-27 03:10:00 |
| 4 | 12.00 | 2018-12-27 03:12:00 |
| 5 | 13.00 | 2018-12-27 03:13:00 |
| 6 | 14.00 | 2018-12-27 03:20:00 |
| 7 | 10.00 | 2018-12-27 04:00:00 |
| 8 | 10.00 | 2018-12-27 05:01:00 |
| 9 | 11.00 | 2018-12-27 06:10:00 |
| 10 | 12.00 | 2018-12-27 07:12:00 |
| 11 | 13.00 | 2018-12-27 08:13:00 |
| 12 | 23.00 | 2018-12-27 09:20:00 |
+----+-------+---------------------+
*/


谢。。。。谢谢了,我还是用代码过滤一下吧。。。。。
吉普赛的歌 2018-12-27
  • 打赏
  • 举报
回复
drop table if exists t;
create table t(
	id int not null AUTO_INCREMENT primary key,
	wd DECIMAL(10,2),
	addTime datetime
);
INSERT t (wd,addTime) values(10,'2018-12-27 03:00');
INSERT t (wd,addTime) values(10,'2018-12-27 03:01');
INSERT t (wd,addTime) values(11,'2018-12-27 03:10');
INSERT t (wd,addTime) values(12,'2018-12-27 03:12');
INSERT t (wd,addTime) values(13,'2018-12-27 03:13');
INSERT t (wd,addTime) values(14,'2018-12-27 03:20');
INSERT t (wd,addTime) values(10,'2018-12-27 04:00');
INSERT t (wd,addTime) values(10,'2018-12-27 05:01');
INSERT t (wd,addTime) values(11,'2018-12-27 06:10');
INSERT t (wd,addTime) values(12,'2018-12-27 07:12');
INSERT t (wd,addTime) values(13,'2018-12-27 08:13');
INSERT t (wd,addTime) values(23,'2018-12-27 09:20');
# 以上为测试数据

/*
1. 查询现在时间8小时以内的记录,8小时里每个小时取第一条和第六条记录,一共取16条记录,但是当前时间这个小时内可能没有这么多记录,那么只取第一条就行
*/
select * from (
select 
(
  SELECT COUNT(*) FROM t t2 WHERE 
  1=1
   AND DATE_FORMAT(t1.addTime,'%Y-%m-%d %H')= DATE_FORMAT(t2.addTime,'%Y-%m-%d %H') 
  AND t1.id >= t2.id
) as rid
,id
,wd
,addTime
from t as t1 where t1.addTime>DATE_ADD(t1.addTime,INTERVAL -8 hour)
) as tt
where rid in (1,6);
/*
+-----+----+-------+---------------------+
| rid | id | wd    | addTime             |
+-----+----+-------+---------------------+
|   1 |  1 | 10.00 | 2018-12-27 03:00:00 |
|   6 |  6 | 14.00 | 2018-12-27 03:20:00 |
|   1 |  7 | 10.00 | 2018-12-27 04:00:00 |
|   1 |  8 | 10.00 | 2018-12-27 05:01:00 |
|   1 |  9 | 11.00 | 2018-12-27 06:10:00 |
|   1 | 10 | 12.00 | 2018-12-27 07:12:00 |
|   1 | 11 | 13.00 | 2018-12-27 08:13:00 |
|   1 | 12 | 23.00 | 2018-12-27 09:20:00 |
+-----+----+-------+---------------------+
*/

/*
2. 取8小时内温度有变化的记录,比如第一条记录23度,第二条记录23度,第三条记录23.1度,第四条记录24度,那么返回数据集应该是第一条、第三条、第四条记录,因为第一条作为起始点需要保留
*/
drop TEMPORARY TABLE if exists tmp;
drop TEMPORARY TABLE if exists tmp2;
CREATE TEMPORARY  TABLE tmp(
	rid int,
	id int,
	wd DECIMAL(10,2),
	addTime datetime,
	timeSeg int
);
CREATE TEMPORARY  TABLE tmp2(
	rid int,
	id int,
	wd DECIMAL(10,2),
	addTime datetime,
	timeSeg int
);

insert into tmp
select * from (
select 
(
  SELECT COUNT(*) FROM t t2 WHERE 
  1=1
  AND DATE_FORMAT(t1.addTime,'%Y-%m-%d %H')= DATE_FORMAT(t2.addTime,'%Y-%m-%d %H') 
  AND t1.id >= t2.id
) as rid
,id
,wd
,addTime
,DATE_FORMAT(t1.addTime,'%Y%m%d%H') as timeSeg
from t as t1 where t1.addTime>DATE_ADD(t1.addTime,INTERVAL -8 hour)
) as tt
;
insert into tmp2
select * from tmp;

select 
id
,wd
,addTime
from (
select a.*,case when a.rid=1 or (b.wd is not null and a.wd!=b.wd) then 1 else 0 end as r from tmp as a 
    left join tmp2 as b on a.timeSeg=b.timeSeg and a.rid=b.rid+1
) as tt
where tt.r=1
order by tt.timeSeg,tt.rid
;
/*
+----+-------+---------------------+
| id | wd    | addTime             |
+----+-------+---------------------+
|  1 | 10.00 | 2018-12-27 03:00:00 |
|  3 | 11.00 | 2018-12-27 03:10:00 |
|  4 | 12.00 | 2018-12-27 03:12:00 |
|  5 | 13.00 | 2018-12-27 03:13:00 |
|  6 | 14.00 | 2018-12-27 03:20:00 |
|  7 | 10.00 | 2018-12-27 04:00:00 |
|  8 | 10.00 | 2018-12-27 05:01:00 |
|  9 | 11.00 | 2018-12-27 06:10:00 |
| 10 | 12.00 | 2018-12-27 07:12:00 |
| 11 | 13.00 | 2018-12-27 08:13:00 |
| 12 | 23.00 | 2018-12-27 09:20:00 |
+----+-------+---------------------+
*/
吉普赛的歌 2018-12-27
  • 打赏
  • 举报
回复
drop table if exists t;
create table t(
	id int not null AUTO_INCREMENT primary key,
	wd DECIMAL(10,2),
	addTime datetime
);
INSERT t (wd,addTime) values(10,'2018-12-27 03:00');
INSERT t (wd,addTime) values(10,'2018-12-27 03:01');
INSERT t (wd,addTime) values(11,'2018-12-27 03:10');
INSERT t (wd,addTime) values(12,'2018-12-27 03:12');
INSERT t (wd,addTime) values(13,'2018-12-27 03:13');
INSERT t (wd,addTime) values(14,'2018-12-27 03:20');
INSERT t (wd,addTime) values(10,'2018-12-27 04:00');
INSERT t (wd,addTime) values(10,'2018-12-27 05:01');
INSERT t (wd,addTime) values(11,'2018-12-27 06:10');
INSERT t (wd,addTime) values(12,'2018-12-27 07:12');
INSERT t (wd,addTime) values(13,'2018-12-27 08:13');
INSERT t (wd,addTime) values(23,'2018-12-27 09:20');
# 以上为测试数据

/*
1. 查询现在时间8小时以内的记录,8小时里每个小时取第一条和第六条记录,一共取16条记录,但是当前时间这个小时内可能没有这么多记录,那么只取第一条就行
*/
select * from (
select 
(
  SELECT COUNT(*) FROM t t2 WHERE 
  1=1
   AND DATE_FORMAT(t1.addTime,'%Y-%m-%d %H')= DATE_FORMAT(t2.addTime,'%Y-%m-%d %H') 
  AND t1.id >= t2.id
) as rid
,id
,wd
,addTime
from t as t1 where t1.addTime>DATE_ADD(t1.addTime,INTERVAL -8 hour)
) as tt
where rid in (1,6);
/*
+-----+----+-------+---------------------+
| rid | id | wd    | addTime             |
+-----+----+-------+---------------------+
|   1 |  1 | 10.00 | 2018-12-27 03:00:00 |
|   6 |  6 | 14.00 | 2018-12-27 03:20:00 |
|   1 |  7 | 10.00 | 2018-12-27 04:00:00 |
|   1 |  8 | 10.00 | 2018-12-27 05:01:00 |
|   1 |  9 | 11.00 | 2018-12-27 06:10:00 |
|   1 | 10 | 12.00 | 2018-12-27 07:12:00 |
|   1 | 11 | 13.00 | 2018-12-27 08:13:00 |
|   1 | 12 | 23.00 | 2018-12-27 09:20:00 |
+-----+----+-------+---------------------+
*/
邹小青 2018-12-27
  • 打赏
  • 举报
回复
《如何协助MySQL实现窗口函数》这篇文章介绍得方法,可以参考一下

56,677

社区成员

发帖
与我相关
我的任务
社区描述
MySQL相关内容讨论专区
社区管理员
  • MySQL
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧