u010463375 2013-07-02 04:57 采纳率: 50%
浏览 5766

求帮助,oracle数据库,查询出每个最新时间的那一条数据

select p.* from (select rownum as 序号 ,n.* from (select sitename as 站点名称, RecordTime as 记录时间 ,decode(avg(case item when 211 then value else null end),0,'0.00000',trim(to_char(avg(case item when 211 then value else null end),'99999999999990.99999'))) "SO2(mg/m3)" from(select s.sitename,m.* from air_temphourdata m left join site s on m.sitecode=s.sitecode where m.SiteCode in ('34656-31102001','34656-31102006'))group by sitename,Recordtime having to_char(Recordtime,'yyyymmddhhmmss')=MAX(to_char(Recordtime,'yyyymmddhhmmss')) order by RecordTime desc ) n )p where p.序号 between 1 and 15 只查询出每个站点最大时间的那一条

  • 写回答

1条回答

  • com_jia 2018-03-16 07:28
    关注

    很简单的问题,使用窗口函数解决~
    select 站点名称,first_value("SO2(mg/m3)") over(partition by 站点名称 order by 记录时间 desc)
    from (
    select sitename as 站点名称,
    RecordTime as 记录时间,
    decode(avg(case item
    when 211 then
    value
    else
    null
    end),
    0,
    '0.00000',
    trim(to_char(avg(case item
    when 211 then
    value
    else
    null
    end),
    '99999999999990.99999'))) "SO2(mg/m3)"
    from (select s.sitename, m.*
    from air_temphourdata m
    left join site s
    on m.sitecode = s.sitecode
    where m.SiteCode in ('34656-31102001', '34656-31102006'))) n

    评论

报告相同问题?

悬赏问题

  • ¥15 js调用html页面需要隐藏某个按钮
  • ¥15 ads仿真结果在圆图上是怎么读数的
  • ¥20 Cotex M3的调试和程序执行方式是什么样的?
  • ¥20 java项目连接sqlserver时报ssl相关错误
  • ¥15 一道python难题3
  • ¥15 牛顿斯科特系数表表示
  • ¥15 arduino 步进电机
  • ¥20 程序进入HardFault_Handler
  • ¥15 关于#python#的问题:自动化测试
  • ¥20 问题请教!vue项目关于Nginx配置nonce安全策略的问题