zoukankan      html  css  js  c++  java
  • 求助:关于sql如何统计时间的问题

    三、现在我们假设应用计时分为app应用和web应用,需要考虑如下几个方面:

    (1)多时间段(2)表中有冗杂数据

    (3)用户是在web端和app端都登陆,这种类型的重复时间段只能取其一

    存在数据:

    存在表:应用启动时间统计表Applic_Sessions

    字段:applic    platform     start_time     end_time     status     rowid

                 X          web           11:30              18:33           1           1

                 X          app            11:10              17:50           1           2

                 X          app            17:55              19:55           1           3

                 X          app            20:31              22:31           1           4

                 X          web            02:01              02:40           1           5

    利用sql语句的方式获取到开始时间和结束时间,timestampdiff( )相减得到。

    (1)取出X用户两平台中启动的最小时间

    (2)取出X用户两平台中结束的最大时间

    按照以上步骤,这样会带来一个问题:如rowid 15的记录,相减所得结果明显大于实际结果。

    尝试方案1:将不同平台的数据区分开单独计数:

    (1)select t.* from Applic_Sessions t where t.platform = “web”;

    视图:Web_View

    applic     platform      start_time     end_time      status     rowid

        X         web               11:30              18:33           1           1

        X          web               02:01              02:40           1           2

    select sum(timestampdiff(second,start_time,end_time)) from Web_View;

    (2)select t.* from Applic_Sessions t where t.platform = “app”;

    视图:App_View

    applic      platform     start_time     end_time     status     rowid

        X             app           11:10              17:50            1           1

        X             app           17:55              19:55            1           2

        X             app           20:31              22:31            1           3

    select sum(timestampdiff(second,start_time,end_time)) from Web_View;

    这样求取出单个平台的使用时长,这种适用于:app使用时长可以换取双倍积分 等需求。但是至于中间的重复时间段更加干不掉了,这种方法pass

    方案2

    视图:Applic_Sessions

    applic platform  start_time end_time status rowid

    Xweb      11:30 18:33  1  1

    Xapp      11:10 17:50  1  2

    Xapp      17:55 19:55  1  3

    X app       20:31  22:31   1   4

    X web       02:01  02:40   1   5

    。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。

                                                        11:30............................................18:33(web)

                                        11:10....................17:50(app)

                                                                                            17:55.................19:55(app)

                02:01....02:40                                                                                                      20:31.......22:31

    整理一下数据,发现其中的难点就是:web的使用时长段与app的使用时间段夹杂在一起,其他正常数据横向合并就成,那第一步就是把这些夹杂数据单独拎出来,然后取出最小启动值和最大结束值,相减就好拉:

    写下这个sql,越看越别扭,能行么---显然不行

    select t.* from Applic_Sessions t where

            t.start_time between (select min(t.start_time) from Applic_Sessions t)     

            and (select max(t.end_time) from Applic_Sessions t)

                    and t.end_time between t.start_time and t.end_time;

    至此,卡住了。。。

    绞尽了脑汁,搞不定啊,有哪位大神可以帮帮忙啊,谢谢了

  • 相关阅读:
    命令行参数
    数组的使用
    Hello World 和 模块分解
    20155234 2016-2017-2 《Java程序设计》第2周学习总结
    20155234 2016-2017-2 《Java程序设计》第1 周学习总结
    与虚拟机和linux的初次接触
    优秀技能经验及对java学习展望
    预备作业01
    20155231 实验三 敏捷开发与XP实践
    20155231 第十一周课堂代码练习
  • 原文地址:https://www.cnblogs.com/bling123/p/8493254.html
Copyright © 2011-2022 走看看