doulao5916 2019-02-11 16:31
浏览 21
已采纳

两个时间戳之间无法区分

I want return the number of dates which have a difference less than 30 minutes. These are the records stored in the database:

id | last_login
0    2019-02-11 17:22:47
1    0000-00-00 00:00:00
2    2019-02-11 17:22:03
3    0000-00-00 00:00:00
4    0000-00-00 00:00:00

the result of the query should be 2, but I get 1:

$time = strtotime('+30 minutes');

return $this->db->select('COUNT(last_login) AS users_online')
    ->from('login')
    ->where('UNIX_TIMESTAMP(last_login) < ' . $time)
    ->get()->num_rows();
  • 写回答

1条回答 默认 最新

  • 普通网友 2019-02-11 16:41
    关注

    There are two problems with your code here. The first, is you are cutting everything down to 1 record with an implicit group thanks to count() - and then getting the number of records returned via num_rows().

    The second issue is you are getting every single record in the table where the last login is less than 30 minutes in the future... Which will always be every row.

    echo date('H:i') . "
    " . date('H:i', strtotime('+30 minutes'));
    

    Yields:

    16:38
    17:08
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 宇视监控服务器无法登录
  • ¥15 PADS Logic 原理图
  • ¥15 PADS Logic 图标
  • ¥15 电脑和power bi环境都是英文如何将日期层次结构转换成英文
  • ¥20 气象站点数据求取中~
  • ¥15 如何获取APP内弹出的网址链接
  • ¥15 wifi 图标不见了 不知道怎么办 上不了网 变成小地球了
  • ¥50 STM32单片机传感器读取错误
  • ¥50 power BI 从Mysql服务器导入数据,但连接进去后显示表无数据
  • ¥15 (关键词-阻抗匹配,HFSS,RFID标签天线)