MySQL抽稀_【mysql】数据库查询,怎样按一定时间间隔跳跃查询数据?

我的项目用的是MySQL,但也想同时请教下在Oracle、SqlServer中应该如何处理如下问题:

有数据表如下所示:

希望从表中抽取数据,要求两条记录的时间间隔至少2分钟

对下面图片中的数据而言,假如我查询的时间范围是从2014-08-10 23:20:00开始的,

则希望抽取到如下结果集:

'83', '57', '10041', '74.27', '0', '2014-08-10 23:20:04'

'113', '57', '10041', '59.25', '0', '2014-08-10 23:22:06'

'145', '57', '10041', '96.21', '0', '2014-08-10 23:24:07'

'177', '57', '10041', '34.16', '0', '2014-08-10 23:26:08'

'209', '57', '10041', '39.11', '0', '2014-08-10 23:28:09'

真实的场景是:传感器每隔30秒左右会向数据库里写一条记录,我要取N天的数据绘图,如果一次性查询N天的记录再进行抽稀的话,由于结果集太大,循环次数过多,导致时耗严重。我希望能通过sql语句直接在数据库层面进行数据抽稀,程序里要处理的数据就会少很多。

问题就是,应该如何写SQL语句?谢谢各位!

a054763634e3355ef5d5c6ee2b3a35ed.png

回答

@Chobits 的答案啦,本来想在他下面评论的,想想还是写出来,题主能看到。

select * from (select rank() over(order by HTAH01A060) as rank_sort,* from table)

as a where a.rank_sort%4 = 0

如果不能保证HTAH01A060都不同的话,建议用row_number()

各位好,昨天晚上自己找到了一个方法,基本能满足我的需求。欢迎各位继续讨论~~看看有没有更好的方法~~

/*存储过程:按起始、终止时间,以及时间间隔,抽取数据*/

DELIMITER $$

DROP PROCEDURE IF EXISTS proc_HTAH01A_sampleData $$

CREATE DEFINER=`root`@`localhost` PROCEDURE proc_HTAH01A_sampleData(IN timeBegin DATETIME, IN timeEnd DATETIME, IN timeInterval INT)

BEGIN

SET @time := '1000-01-01 00:00:00';

SET @interval := timeInterval;

SELECT * FROM HTAH01A

WHERE HTAH01A060 >= timeBegin AND HTAH01A060 <= timeEnd

AND TIMESTAMPDIFF( SECOND, @time, HTAH01A060 ) >= @interval

AND @time := htah01a060;

END$$

DELIMITER ;

调用如下:

call proc_HTAH01A_sampleData('2014-08-10 23:20:00', '2014-08-11 05:00:00', 120);

查rank排名 取rank除4余数相同的即可

楼主变通一下思路,反正是绘图,不必一定按照时间间隔查数据;

— MySQL的做法:

select @rank:=0;

select * from(select *,@rank:[email protected]+1 as rank from 你的表名) as dd where dd.rank%间隔参数=0;

SELECT *

FROM `tablename`

WHERE mod( unix_timestamp( `time` ) - unix_timestamp( '2014-08-01 23:59:50' ) , 24 *60 *60 )

BETWEEN 0

AND 20

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值