日期:2014-05-17 浏览次数:21248 次
表 T_SIGNAL id create_time value ------ ------------- ---- 1 2010-03-01 01:00:00 10 2 2010-03-01 01:03:00 10 3 2010-03-01 01:04:00 10 4 2010-03-01 01:05:00 10 5 2010-03-01 01:07:00 10 6 2010-03-01 01:09:00 10 7 2010-03-01 01:12:00 10 8 2010-03-01 01:14:00 10 9 2010-03-01 01:25:00 10 10 2010-03-01 02:10:00 10 按时间间隔4分钟从上表中取数据(每条数据的create_time肯定比上一条的的create_time大于或等于4分钟)。 取得应结果为: id create_time value ------ ------------- ---- 1 2010-03-01 01:00:00 10 3 2010-03-01 01:04:00 10 6 2010-03-01 01:09:00 10 8 2010-03-01 01:14:00 10 9 2010-03-01 01:25:00 10 10 2010-03-01 02:10:00 10 现用一条SQL语句(oracle)实现,该怎么写呢?
select id ,create_time,value (select id ,create_time,value,lag(create_time) over(order by id) as pre_time from T_SIGNAL) where (create_time-pre_time)*24*60>4
------解决方案--------------------
一楼正解,对于这种常规方法不能解决的问题
一般要通过树型结构的语句或者分析函数来处理
关于树型查询的语句start with..connect by可参考
1.http://t.00-1.cn/oracle-01e1a85d6d06f1fd.html
2.http://hi.baidu.com/deepsee/blog/item/67ae46107f4f3ef7c3ce79ea.html
关于分析函可参考
1.http://blog.csdn.net/youjianbo_han_87/archive/2009/06/25/4297867.aspx
2.http://oracle.chinaitlab.com/induction/801521.html
------解决方案--------------------
一楼的写法有点小问题,就是value值如果不一样的话可能会有点问题。
修改了一下写法,如下所示。
还有一个问题,这种写法会等待start with 的树建立完成之后才会过滤每个level的第一个node。好像效率不高。
有没有办法在建立start with的时候就只建立最左边的那一个分支啊。
麻烦高手解答一下。
with t1 as
(
select 1 f1, to_date('2010-03-01 01:00:00','YYYY-MM-DD HH24:MI:SS') f2, 10 f3 from dual
union all
select 2 f1, to_date('2010-03-01 01:03:00','YYYY-MM-DD HH24:MI:SS') f2, 10 f3 from dual
union all
select 3 f1, to_date('2010-03-01 01:04:00','YYYY-MM-DD HH24:MI:SS') f2, 10 f3 from dual
union all
select 4 f1, to_date('2010-03-01 01:05:00','YYYY-MM-DD HH24:MI:SS') f2, 10 f3 from dual
union all
select 5 f1, to_date('2010-03-01 01:07:00','YYYY-MM-DD HH24:MI:SS') f2, 10 f3 from dual
union all