sql 在规定的时间段里读出每半个小时的数据

sql 在规定的时间段里读出每半个小时的数据 .一条语句
图片描述

clipboard.png

clipboard.png

阅读 5.5k
2 个回答

可以使用存储过程来解决,假如你表中有一个时间戳字段timestamp,需要8,9月每半小时的数据,可以创建一个存储过程如下

delimiter $$
CREATE PROCEDURE test()  
begin
    declare begintime int(10);
    set begintime =  unix_timestamp("2016-7-31 23:59:59");
    loop1:LOOP
    IF begintime > unix_timestamp("2016-9-30 23:59:59") then
         leave loop1;
     END IF;
        select * from tablename where timestamp between begintime and begintime+1800;
        set begintime = begintime + 1800;
    END LOOP loop1;
end;$$

基本意思就是每次循环select半小时数据。然后每次循环时间加半小时。
存储过程没有严格测试,不过思路可以参考下。。。

为什么不写条sql然后半小时执行一次读出前半小时内的数据呢?

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
1 篇内容引用
推荐问题
宣传栏