程_序_猿 2017-06-26 10:10 采纳率: 0%
浏览 1440

oracle大表查询优化问题

如下:
有一张表user_action_log(id,user,action_time,action_desc),数据量有点大。
现在要查询某个月用户的记录,展示如下:(用户,时间,第一次操作时间)
user,action_time,first_time,如何比较高效的查询呢?
我的做法如下,但是太慢了:
select a.*,(select min(b.action_time) from user_action_log b where a.user=b.user and b.action_time!=a.action_time) as first_time from user_action_log a where substr(action_time,0,6)='201507'

  • 写回答

1条回答 默认 最新

  • 叶之秋 2017-06-27 02:25
    关注

    select a.*, min(b.action_time) as first_time
    from user_action_log a, user_action_log b
    where substr(action_time, 0, 6) = '201507'
    and a.user = b.user
    and b.action_time != a.action_time

    评论

报告相同问题?

悬赏问题

  • ¥15 fluent的在模拟压强时使用希望得到一些建议
  • ¥15 STM32驱动继电器
  • ¥15 Windows server update services
  • ¥15 关于#c语言#的问题:我现在在做一个墨水屏设计,2.9英寸的小屏怎么换4.2英寸大屏
  • ¥15 模糊pid与pid仿真结果几乎一样
  • ¥15 java的GUI的运用
  • ¥15 Web.config连不上数据库
  • ¥15 我想付费需要AKM公司DSP开发资料及相关开发。
  • ¥15 怎么配置广告联盟瀑布流
  • ¥15 Rstudio 保存代码闪退