无敌小贱 2013-04-20 17:47 采纳率: 0%
浏览 1570
已采纳

mysql统计登录次数或者在线时长

自然周内有3天登陆行为,或累计在线时长达到8小时以上
列名有lastLoginTime(登录时间),lastLogoutTime(退出时间)。这个东西怎么写啊?求大侠拔刀相助!!

  • 写回答

5条回答

  • Dead_Knight 2013-04-20 19:02
    关注

    自然周内有3天登陆行为,或累计在线时长达到8小时以上
    如果lastLoginTime(登录时间),lastLogoutTime(退出时间)这两个字段是在登录日志表中,那么查询sql为:
    1.自然周内有三天登录行为的:
    [code="java"]
    select weekNo,count(1) from (
    SELECT *,WEEK(lastLoginTime) weekNo FROM login_history
    ) t group by t.weekNo having count(1) > 3

    [/code]

    2.累计8小时:
    [code="java"]
    SELECT * FROM login_history WHERE TIMESTAMPDIFF(HOUR,lastLoginTime,lastLogoutTime) > 8
    [/code]

    如果不存在登录日志表,那么这两个字段根本没什么用处,仅仅知道上次登录时间、退出时间。

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(4条)

报告相同问题?

悬赏问题

  • ¥20 求一个html代码,有偿
  • ¥100 关于使用MATLAB中copularnd函数的问题
  • ¥20 在虚拟机的pycharm上
  • ¥15 jupyterthemes 设置完毕后没有效果
  • ¥15 matlab图像高斯低通滤波
  • ¥15 针对曲面部件的制孔路径规划,大家有什么思路吗
  • ¥15 钢筋实图交点识别,机器视觉代码
  • ¥15 如何在Linux系统中,但是在window系统上idea里面可以正常运行?(相关搜索:jar包)
  • ¥50 400g qsfp 光模块iphy方案
  • ¥15 两块ADC0804用proteus仿真时,出现异常