免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 2200 | 回复: 4
打印 上一主题 下一主题

【已解决】请教求指定各段时间内登录的用户数量的sql语句该怎么写? [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2012-09-10 15:12 |只看该作者 |倒序浏览
本帖最后由 cenalulu 于 2012-09-10 17:44 编辑

我有一张记录用户的登录信息表,每行记录一个玩家一次登录的一条信息
比如
Account(帐号名) ConnectDateTime(登录时间)
张三                  2012-09-09 12:00:00
李四                  2012-09-09 17:20:10
张三                  2012-09-10 06:30:30

现在要求一天内每隔4小时当中的用户登录数量,即0点-4点、4点-8点、8点-12点、12点-16点、16点-20点、20点-24点;
输出结果希望为
  1. +------------+------------+------------+------------+------------+------------+
  2. | time_00_04 | time_04_08 | time_08_12 | time_12_16 | time_16_20 | time_20_24 |
  3. +------------+------------+------------+------------+------------+------------+
  4. |        748 |        962 |       3684 |       3498 |       2227 |        919 |
  5. +------------+------------+------------+------------+------------+------------+
复制代码
然后我就写了下面这条语句
但是一个用户可能在0点-4点登录之后,又可能在其他的时间段再次登录;
而我这么用CASE语句,只要之前引用过,之后的CASE就不会再显示,所以之后时间段的数据会比实际的来的少;
特来求助这条数据需求该怎么写,感激不尽
  1. SELECT COUNT(tmp.time_00_04) AS time_00_04,
  2.        COUNT(tmp.time_04_08) AS time_04_08,
  3.        COUNT(tmp.time_08_12) AS time_08_12,
  4.        COUNT(tmp.time_12_16) AS time_12_16,
  5.        COUNT(tmp.time_16_20) AS time_16_20,
  6.        COUNT(tmp.time_20_24) AS time_20_24
  7. FROM
  8. (
  9. SELECT
  10. CASE
  11.         WHEN ConnectDateTime >= '2012-09-09 00:00:00'
  12.          AND ConnectDateTime < '2012-09-09 04:00:00'
  13.         THEN ConnectDateTime
  14. END AS time_00_04,
  15. CASE
  16.         WHEN ConnectDateTime >= '2012-09-09 04:00:00'
  17.          AND ConnectDateTime < '2012-09-09 08:00:00'
  18.         THEN ConnectDateTime
  19. END AS time_04_08,
  20. CASE
  21.         WHEN ConnectDateTime >= '2012-09-09 08:00:00'
  22.          AND ConnectDateTime < '2012-09-09 12:00:00'
  23.         THEN ConnectDateTime
  24. END AS time_08_12,
  25. CASE
  26.         WHEN ConnectDateTime >= '2012-09-09 12:00:00'
  27.          AND ConnectDateTime < '2012-09-09 16:00:00'
  28.         THEN ConnectDateTime
  29. END AS time_12_16,
  30. CASE
  31.         WHEN ConnectDateTime >= '2012-09-09 16:00:00'
  32.          AND ConnectDateTime < '2012-09-09 20:00:00'
  33.         THEN ConnectDateTime
  34. END AS time_16_20,
  35. CASE
  36.         WHEN ConnectDateTime >= '2012-09-09 20:00:00'
  37.          AND ConnectDateTime < '2012-09-09 24:00:00'
  38.         THEN ConnectDateTime
  39. END AS time_20_24
  40. FROM login_account
  41. WHERE ConnectDateTime >= '2012-09-09 00:00:00'
  42.    AND ConnectDateTime <= '2012-09-09 23:59:59'
  43. GROUP BY Account) tmp;
复制代码

论坛徽章:
9
每日论坛发贴之星
日期:2016-01-04 06:20:00数据库技术版块每日发帖之星
日期:2016-01-04 06:20:00每日论坛发贴之星
日期:2016-01-04 06:20:00数据库技术版块每日发帖之星
日期:2016-01-04 06:20:00IT运维版块每日发帖之星
日期:2016-01-04 06:20:00IT运维版块每日发帖之星
日期:2016-01-04 06:20:00综合交流区版块每日发帖之星
日期:2016-01-04 06:20:00综合交流区版块每日发帖之星
日期:2016-01-04 06:20:00数据库技术版块每周发帖之星
日期:2016-03-07 16:30:25
2 [报告]
发表于 2012-09-10 15:32 |只看该作者
  1. SELECT
  2.        COUNT(if(ConnectDateTime >= '2012-09-09 00:00:00'          AND ConnectDateTime < '2012-09-09 04:00:00', 1,null) ) AS time_00_04,
  3.        COUNT(if(ConnectDateTime >= '2012-09-09 04:00:00'          AND ConnectDateTime < '2012-09-09 08:00:00', 1,null) ) AS time_04_08,
  4.        COUNT(if(ConnectDateTime >= '2012-09-09 08:00:00'          AND ConnectDateTime < '2012-09-09 12:00:00', 1,null) ) AS time_08_12,
  5.        COUNT(if(ConnectDateTime >= '2012-09-09 12:00:00'          AND ConnectDateTime < '2012-09-09 16:00:00', 1,null) ) AS time_12_16,
  6.        COUNT(if(ConnectDateTime >= '2012-09-09 16:00:00'          AND ConnectDateTime < '2012-09-09 20:00:00', 1,null) ) AS time_16_20,
  7.        COUNT(if(ConnectDateTime >= '2012-09-09 20:00:00'          AND ConnectDateTime < '2012-09-09 24:00:00', 1,null) ) AS time_20_24
  8. FROM login_account
  9. WHERE ConnectDateTime >= '2012-09-09 00:00:00'
  10.    AND ConnectDateTime <= '2012-09-09 23:59:59'
  11. GROUP BY Account
复制代码

论坛徽章:
0
3 [报告]
发表于 2012-09-10 15:50 |只看该作者
回复 2# cenalulu

这个执行结果变成这样了...
  1. +------------+------------+------------+------------+------------+------------+
  2. | time_00_04 | time_04_08 | time_08_12 | time_12_16 | time_16_20 | time_20_24 |
  3. +------------+------------+------------+------------+------------+------------+
  4. |          0 |          1 |          0 |          1 |          1 |          1 |
  5. |          0 |          1 |          0 |          0 |          0 |          0 |
  6. |          0 |          0 |          1 |          0 |          0 |          0 |
  7. |          0 |          0 |          0 |          1 |          0 |          0 |
  8. |          0 |          0 |          2 |          1 |          0 |          0 |
  9. |          0 |          0 |          0 |          0 |          0 |          1 |
  10. |          0 |          2 |          0 |          2 |          0 |          0 |
  11. |          0 |          0 |          0 |          5 |          0 |          0 |
  12. |          0 |          0 |          0 |          0 |          2 |          0 |
  13. |          0 |          0 |          0 |          1 |          0 |          0 |
  14. |          0 |          0 |          0 |          0 |          1 |          0 |
  15. |          0 |          0 |          0 |          1 |          1 |          0 |
  16. |          0 |          0 |          1 |          0 |          0 |          0 |
  17. |          0 |          0 |          0 |          0 |          0 |          2 |
  18. |          0 |          0 |          0 |          1 |          0 |          0 |
  19. |          0 |          1 |          1 |          1 |          0 |          0 |
  20. |          0 |          0 |          0 |          0 |          4 |          0 |
  21. |          0 |          0 |          1 |          0 |          0 |          0 |
  22. |          0 |          2 |          5 |          0 |          0 |          0 |
复制代码

论坛徽章:
0
4 [报告]
发表于 2012-09-10 16:17 |只看该作者
本帖最后由 joker_buggy 于 2012-09-10 16:17 编辑

回复 2# cenalulu
  1. SELECT SUM(tmp.time_00_04) AS time_00_04,
  2.        SUM(tmp.time_04_08) AS time_04_08,
  3.        SUM(tmp.time_08_12) AS time_08_12,
  4.        SUM(tmp.time_12_16) AS time_12_16,
  5.        SUM(tmp.time_16_20) AS time_16_20,
  6.        SUM(tmp.time_20_24) AS time_20_24
  7. FROM (
  8. SELECT
  9.         COUNT(DISTINCT if(ConnectDateTime >= '2012-09-09 00:00:00' AND ConnectDateTime < '2012-09-09 04:00:00', 1,null) ) AS time_00_04,
  10.         COUNT(DISTINCT if(ConnectDateTime >= '2012-09-09 04:00:00' AND ConnectDateTime < '2012-09-09 08:00:00', 1,null) ) AS time_04_08,
  11.         COUNT(DISTINCT if(ConnectDateTime >= '2012-09-09 08:00:00' AND ConnectDateTime < '2012-09-09 12:00:00', 1,null) ) AS time_08_12,
  12.         COUNT(DISTINCT if(ConnectDateTime >= '2012-09-09 12:00:00' AND ConnectDateTime < '2012-09-09 16:00:00', 1,null) ) AS time_12_16,
  13.         COUNT(DISTINCT if(ConnectDateTime >= '2012-09-09 16:00:00' AND ConnectDateTime < '2012-09-09 20:00:00', 1,null) ) AS time_16_20,
  14.         COUNT(DISTINCT if(ConnectDateTime >= '2012-09-09 20:00:00' AND ConnectDateTime < '2012-09-09 24:00:00', 1,null) ) AS time_20_24
  15. FROM login_account
  16. WHERE ConnectDateTime >= '2012-09-09 00:00:00'
  17.    AND ConnectDateTime <= '2012-09-09 23:59:59'
  18. GROUP BY Account) AS tmp;
复制代码
OK了,在你的基础上修改下就好了,非常感谢!
   

论坛徽章:
8
戌狗
日期:2014-09-26 16:39:44水瓶座
日期:2014-10-10 02:06:57金牛座
日期:2014-10-11 23:04:042015亚冠之首尔
日期:2015-06-23 15:37:0015-16赛季CBA联赛之天津
日期:2016-01-22 18:58:2915-16赛季CBA联赛之佛山
日期:2016-05-31 19:18:0815-16赛季CBA联赛之同曦
日期:2016-08-10 16:26:3315-16赛季CBA联赛之辽宁
日期:2018-01-10 11:47:40
5 [报告]
发表于 2012-09-10 20:37 |只看该作者
强大的sql语句  学习了
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP